/* ───────── Proteção de Dados — page styles ───────── */

/* === DPHero === */
.dphero {
  padding: 72px 0 120px; background: var(--paper);
  border-bottom: 1px solid rgba(11,10,8,.08);
  position: relative; overflow: hidden;
}
.dphero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(800px 500px at 85% 20%, rgba(117,64,172,.06), transparent 60%),
    radial-gradient(600px 400px at 15% 80%, rgba(248,173,57,.04), transparent 60%);
}
.dphero > .wrap { position: relative; z-index: 1; }

/* Mast bar (matches Opening) */
.dphero__mast {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 0 24px; margin-bottom: 56px;
  border-bottom: 1px solid rgba(11,10,8,.08);
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-4);
}
.dphero__mast-L { display: flex; gap: 28px; }
.dphero__mast-R { display: flex; align-items: center; }
.dphero__mast-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(16,185,129,.1); color: #10B981;
  font-weight: 600; letter-spacing: .12em;
}
.dphero__mast-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #10B981;
  box-shadow: 0 0 0 0 rgba(16,185,129,.6);
  animation: dphero-mast-pulse 1.8s ease-in-out infinite;
}
@keyframes dphero-mast-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(16,185,129,.6); }
  50%     { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
}

/* Hero grid (matches Opening 2-col) */
.dphero__grid {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center;
}
.dphero__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(60px, 8.4vw, 132px); line-height: .92;
  letter-spacing: -0.028em; color: var(--ink); margin: 28px 0 32px;
}
.dphero__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-purple) 0%, var(--wir-coral) 60%, var(--wir-amber) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dphero__lede {
  font-size: 19px; line-height: 1.55; color: var(--ink-2);
  text-wrap: pretty; max-width: 540px;
}
.dphero__actions {
  display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px;
}
.dphero__caption {
  font-family: var(--f-mono); font-size: 11px; color: var(--ink-4);
  letter-spacing: .14em; text-transform: uppercase; margin-bottom: 18px;
  text-align: center;
}
.dphero__shield {
  display: flex; justify-content: center; align-items: center;
  width: 100%; max-width: 480px; margin: 0 auto;
  padding: 24px;
  background: var(--paper-2);
  border: 1px solid rgba(11,10,8,.08);
  border-radius: 16px;
}
.dphero__shield-svg {
  width: 100%; height: auto; display: block;
  animation: dphero-shield-spin 60s linear infinite;
}
@keyframes dphero-shield-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.dphero__shield-svg > g, .dphero__shield-svg > text {
  /* Don't rotate text inside */
  animation: dphero-shield-counterspin 60s linear infinite;
  transform-origin: center;
}
@keyframes dphero-shield-counterspin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

@media (max-width: 900px) {
  .dphero__grid { grid-template-columns: 1fr; gap: 48px; }
  .dphero__shield { max-width: 380px; }
}

/* === DPApproach (essay matching AboutEssay) === */
.dpessay {
  padding: 140px 0; background: var(--paper-2);
  border-bottom: 1px solid rgba(11,10,8,.08);
}
.dpessay__grid {
  display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start;
}
.dpessay__side { position: sticky; top: 120px; }
.dpessay__pullquote {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(28px, 2.6vw, 38px); line-height: 1.2;
  letter-spacing: -0.015em; color: var(--ink); margin: 24px 0 24px;
}
.dpessay__pullquote em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-purple), var(--wir-coral));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dpessay__attr {
  display: flex; flex-direction: column; gap: 4px;
  padding-top: 16px; border-top: 1px solid rgba(11,10,8,.1);
}
.dpessay__attr b { font-size: 14px; font-weight: 600; color: var(--ink); }
.dpessay__attr span {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-4);
}
.dpessay__content { display: flex; flex-direction: column; gap: 48px; }
.dpessay__para-k {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--ink-4); margin-bottom: 14px;
}
.dpessay__para-t {
  font-size: 18px; line-height: 1.6; color: var(--ink-2);
  text-wrap: pretty;
}
@media (max-width: 900px) {
  .dpessay__grid { grid-template-columns: 1fr; gap: 48px; }
  .dpessay__side { position: static; }
}

/* === DPPillars (paper aesthetic, matches site card style) === */
.dppillars {
  padding: 140px 0; background: var(--paper);
  border-bottom: 1px solid rgba(11,10,8,.08);
}
.dppillars__head { max-width: 760px; margin-bottom: 64px; }
.dppillars__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(44px, 5.4vw, 80px); line-height: 1.0;
  letter-spacing: -0.025em; color: var(--ink); margin: 12px 0 24px;
}
.dppillars__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-purple), var(--wir-coral), var(--wir-amber));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dppillars__sub {
  font-size: 17px; line-height: 1.55; color: var(--ink-3);
  max-width: 660px; text-wrap: pretty;
}
.dppillars__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-left: 1px solid rgba(11,10,8,.08);
  border-top: 1px solid rgba(11,10,8,.08);
  border-radius: 12px; overflow: hidden;
  background: var(--paper-2);
}
.dppillars__card {
  padding: 32px 28px 30px;
  border-right: 1px solid rgba(11,10,8,.08);
  border-bottom: 1px solid rgba(11,10,8,.08);
  display: flex; flex-direction: column; gap: 14px;
  background: var(--paper);
  position: relative; transition: background .3s ease;
}
.dppillars__card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--c); transform: scaleX(0); transform-origin: left;
  transition: transform .4s ease;
}
.dppillars__card:hover { background: var(--paper-2); }
.dppillars__card:hover::before { transform: scaleX(1); }
.dppillars__icon {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: color-mix(in srgb, var(--c) 8%, var(--paper));
  border-radius: 10px;
}
.dppillars__k {
  font-family: var(--f-display); font-weight: 500;
  font-size: 22px; color: var(--ink); letter-spacing: -0.01em;
  line-height: 1.15;
}
.dppillars__d {
  font-size: 14.5px; line-height: 1.55; color: var(--ink-3); margin: 0;
}
.dppillars__bullets {
  list-style: none; padding: 0; margin: 8px 0 0;
  display: flex; flex-direction: column; gap: 8px;
}
.dppillars__bullets li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; line-height: 1.45; color: var(--ink-2);
}
.dppillars__bu {
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; margin-top: 7px; flex-shrink: 0;
}
.dppillars__stack {
  margin-top: 48px; padding: 24px 28px;
  background: var(--paper-2);
  border: 1px solid rgba(11,10,8,.08);
  border-radius: 12px;
}
.dppillars__stack-k {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-4); display: block; margin-bottom: 10px;
}
.dppillars__stack-row {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  font-family: var(--f-mono); font-size: 13px; color: var(--ink-3);
}
.dppillars__stack-row b { color: var(--ink); font-weight: 600; }

@media (max-width: 1100px) {
  .dppillars__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .dppillars__grid { grid-template-columns: 1fr; }
}

/* === DPCompliance === */
.dpcomp {
  padding: 140px 0; background: var(--paper-2);
  border-bottom: 1px solid rgba(11,10,8,.08);
}
.dpcomp__head { margin-bottom: 56px; max-width: 720px; }
.dpcomp__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(40px, 5vw, 72px); line-height: 1.05;
  letter-spacing: -0.022em; color: var(--ink); margin: 12px 0 0;
}
.dpcomp__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-purple), var(--wir-amber));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dpcomp__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-left: 1px solid rgba(11,10,8,.08);
  border-top: 1px solid rgba(11,10,8,.08);
  border-radius: 12px; overflow: hidden;
  background: var(--paper);
}
.dpcomp__cell {
  padding: 32px 28px;
  border-right: 1px solid rgba(11,10,8,.08);
  border-bottom: 1px solid rgba(11,10,8,.08);
  display: flex; flex-direction: column; gap: 12px;
  position: relative; transition: background .3s ease;
}
.dpcomp__cell::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--c); opacity: 0.7;
}
.dpcomp__cell:hover { background: var(--paper-2); }
.dpcomp__cell-top {
  display: flex; justify-content: space-between; align-items: center;
}
.dpcomp__k {
  font-family: var(--f-mono); font-size: 12px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--ink-2); font-weight: 700;
}
.dpcomp__state {
  width: 24px; height: 24px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800;
}
.dpcomp__state--ok  { background: rgba(16,185,129,.15); color: #10B981; }
.dpcomp__state--wip { background: rgba(248,173,57,.18); color: #B07410; }
.dpcomp__v {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(28px, 3vw, 42px); line-height: 1.05; color: var(--ink);
}
.dpcomp__v em {
  font-style: italic;
  background: linear-gradient(90deg, var(--c), var(--wir-amber));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dpcomp__d { font-size: 13.5px; color: var(--ink-3); line-height: 1.55; }

@media (max-width: 900px) {
  .dpcomp__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .dpcomp__grid { grid-template-columns: 1fr; }
}

/* === DPFAQ (matches AboutFAQ) === */
.dpfaq {
  padding: 140px 0; background: var(--paper);
  border-bottom: 1px solid rgba(11,10,8,.08);
}
.dpfaq__head { max-width: 700px; margin-bottom: 56px; }
.dpfaq__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(36px, 4.4vw, 60px); line-height: 1.05;
  letter-spacing: -0.022em; color: var(--ink); margin: 12px 0 0;
}
.dpfaq__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-purple), var(--wir-coral));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dpfaq__list {
  border-top: 1px solid rgba(11,10,8,.1);
}
.dpfaq__item {
  border-bottom: 1px solid rgba(11,10,8,.1);
}
.dpfaq__q {
  width: 100%; display: flex; gap: 24px; align-items: center;
  padding: 24px 0; background: transparent; border: 0; cursor: pointer;
  text-align: left; transition: opacity .2s ease;
}
.dpfaq__q:hover { opacity: 0.7; }
.dpfaq__idx {
  font-family: var(--f-mono); font-size: 12px; letter-spacing: .14em;
  color: var(--ink-4); flex-shrink: 0; min-width: 40px;
}
.dpfaq__qt {
  flex: 1;
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(18px, 1.8vw, 24px); line-height: 1.3; color: var(--ink);
}
.dpfaq__chev {
  font-family: var(--f-mono); font-size: 22px; color: var(--wir-purple);
  width: 28px; text-align: center;
}
.dpfaq__a {
  overflow: hidden; transition: max-height .4s ease;
}
.dpfaq__a p {
  padding: 0 0 28px 64px; max-width: 800px;
  font-size: 16px; line-height: 1.6; color: var(--ink-2);
  text-wrap: pretty; margin: 0;
}
.dpfaq__item.is-open .dpfaq__chev { color: var(--wir-amber); }

/* === DPClose (dark) === */
.dpclose {
  padding: 120px 0; background: #0B0A08; color: #fff;
}
.dpclose__grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: center;
}
.dpclose__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(44px, 5.4vw, 88px); line-height: 1.0;
  letter-spacing: -0.025em; color: #fff; margin: 16px 0 0;
}
.dpclose__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--wir-amber), var(--wir-coral));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.dpclose__r p {
  font-size: 17px; line-height: 1.6; color: rgba(255,255,255,.78);
  text-wrap: pretty; margin: 0 0 28px;
}
.dpclose__actions { display: flex; gap: 14px; flex-wrap: wrap; }

@media (max-width: 900px) {
  .dpclose__grid { grid-template-columns: 1fr; gap: 32px; }
}
