/* doClima brand tokens — Montserrat-only, no italic accents */

@font-face { font-family: 'Montserrat'; src: url('fonts/Montserrat-VariableFont_wght.ttf') format('truetype-variations'); font-weight: 100 900; font-style: normal; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('fonts/Inter-VariableFont_opsz_wght.ttf') format('truetype-variations'); font-weight: 100 900; font-style: normal; font-display: swap; }

:root {
  --dc-ink:        #1E3C42;
  --dc-teal:       #397F94;
  --dc-orange:     #F38C48;
  --dc-yellow:     #FAC461;
  --dc-lime:       #DDE390;
  --dc-cream:      #FAF3DB;

  --dc-teal-1:     #4297B0;
  --dc-teal-2:     #55C7D2;
  --dc-green-1:    #99D5B1;
  --dc-cream-1:    #ECF0C3;
  --dc-yellow-1:   #FCDD76;
  --dc-orange-1:   #F8AA4E;
  --dc-orange-2:   #F38C48;

  --dc-ink-70:     rgba(30,60,66,0.7);
  --dc-ink-60:     rgba(30,60,66,0.6);
  --dc-ink-45:     rgba(30,60,66,0.45);
  --dc-ink-20:     rgba(30,60,66,0.2);
  --dc-ink-10:     rgba(30,60,66,0.1);
  --dc-ink-05:     rgba(30,60,66,0.05);

  --dc-cream-deep: #F2E8C4;
  --dc-cream-warm: #FAF8F3;
  --dc-paper:      #FFFFFF;

  /* Montserrat for everything per user request */
  --dc-display: 'Montserrat', 'Inter', system-ui, -apple-system, sans-serif;
  --dc-sans:    'Montserrat', 'Inter', system-ui, -apple-system, sans-serif;
  --dc-serif:   'Montserrat', 'Inter', system-ui, sans-serif;

  --dc-tr: 0.22s cubic-bezier(.2,.7,.3,1);
  --dc-r-sm: 6px;
  --dc-r:    14px;
  --dc-r-lg: 28px;
}

.dc-site, .dc-site *, .dc-site *::before, .dc-site *::after { box-sizing: border-box; }
.dc-site {
  font-family: var(--dc-sans);
  color: var(--dc-ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.dc-site a:not([class*="dc-btn"]) { color: inherit; text-decoration: none; }
.dc-site a[class*="dc-btn"] { text-decoration: none; }
.dc-site button { font-family: inherit; cursor: pointer; }

/* No italics globally — user requested */
.dc-site em, .dc-site i, .dc-site cite { font-style: normal; }

@keyframes dc-float-slow {
  0%, 100% { transform: translate(0,0) rotate(0deg); }
  50%      { transform: translate(8px,-12px) rotate(2deg); }
}
@keyframes dc-float-med {
  0%, 100% { transform: translate(0,0) rotate(0deg); }
  50%      { transform: translate(-10px,8px) rotate(-3deg); }
}
.dc-float-slow { animation: dc-float-slow 12s ease-in-out infinite; }
.dc-float-med  { animation: dc-float-med  9s ease-in-out infinite; }

.dc-site ::selection { background: var(--dc-yellow); color: var(--dc-ink); }

/* ──────────────────────────────────────────────────────────────────
   White-first background policy.
   The legacy cream/paper tokens still drive text-on-ink colors
   (so .dc-sec--ink and similar dark sections keep their cream type),
   but any element using them as BACKGROUND is normalized to white
   or a near-white off-white for very subtle section alternation.
   ────────────────────────────────────────────────────────────────── */
html, body.dc-site { background: #ffffff; }

/* Inline `style="background: var(--dc-cream)"` sections — keep a hint of
   warmth so adjacent sections still read as bands, but barely. */
[style*="background:var(--dc-cream)"],
[style*="background: var(--dc-cream)"],
[style*="background:var(--dc-cream-warm)"],
[style*="background: var(--dc-cream-warm)"],
[style*="background:var(--dc-cream-deep)"],
[style*="background: var(--dc-cream-deep)"] {
  background: #FAF8F3 !important;
}
[style*="background:var(--dc-paper)"],
[style*="background: var(--dc-paper)"],
[style*="background:#FBF6E2"],
[style*="background: #FBF6E2"],
[style*="background:#FAF3DB"],
[style*="background: #FAF3DB"] {
  background: #ffffff !important;
}
/* doClima site styles — Montserrat-only, no italic, identity colors */

html, body.dc-site { background: #ffffff; color: var(--dc-ink); color-scheme: light; }

.dc-page { scroll-padding-top: 84px; }

.dc-sec { padding: 96px 0; position: relative; }
.dc-sec--sm { padding: 64px 0; }
.dc-sec--lg { padding: 128px 0; }
.dc-wrap  { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.dc-wrap--sm { max-width: 880px; margin: 0 auto; padding: 0 32px; }

.dc-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--dc-orange);
}
.dc-eyebrow::before { content: ''; width: 28px; height: 1px; background: currentColor; }

.dc-h1 { font-family: var(--dc-display); font-weight: 700; font-size: clamp(44px, 6vw, 76px); line-height: 1.04; letter-spacing: -0.025em; margin: 0; color: var(--dc-ink); }
.dc-h1 .dc-accent { color: var(--dc-orange); font-weight: 600; }
.dc-h2 { font-family: var(--dc-display); font-weight: 700; font-size: clamp(32px, 3.6vw, 52px); line-height: 1.1; letter-spacing: -0.02em; margin: 0; color: var(--dc-ink); }
.dc-h2 .dc-accent { color: var(--dc-orange); font-weight: 600; }
.dc-h3 { font-family: var(--dc-display); font-weight: 700; font-size: 26px; line-height: 1.2; letter-spacing: -0.012em; margin: 0; color: var(--dc-ink); }

.dc-lead { font-size: 19px; line-height: 1.6; color: var(--dc-ink-70); max-width: 64ch; margin: 0; text-wrap: pretty; }
.dc-body { font-size: 16px; line-height: 1.7; color: var(--dc-ink-70); }
.dc-body p + p { margin-top: 1em; }

.dc-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px; border-radius: 999px; font-size: 14px; font-weight: 600;
  border: 1px solid transparent; cursor: pointer; transition: all var(--dc-tr);
  font-family: inherit; text-decoration: none; white-space: nowrap;
}
.dc-btn--primary { background: var(--dc-orange); color: var(--dc-cream); }
.dc-btn--primary:hover { background: var(--dc-ink); transform: translateY(-1px); }
.dc-btn--ink { background: var(--dc-ink); color: var(--dc-cream); }
.dc-btn--ink:hover { background: var(--dc-orange); transform: translateY(-1px); }
.dc-btn--ghost { background: transparent; color: var(--dc-ink); border-color: var(--dc-ink-20); }
.dc-btn--ghost:hover { border-color: var(--dc-ink); background: var(--dc-ink-05); }
.dc-btn--ghost-cream { background: transparent; color: var(--dc-cream); border-color: rgba(250,243,219,0.3); }
.dc-btn--ghost-cream:hover { border-color: var(--dc-yellow); color: var(--dc-yellow); }
.dc-btn--sm { padding: 10px 18px; font-size: 13px; }

.dc-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 11px; border-radius: 999px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  background: var(--dc-cream); color: var(--dc-ink); border: 1px solid var(--dc-ink-10);
}
.dc-badge--rec  { background: var(--dc-orange); border-color: transparent; color: var(--dc-cream); }
.dc-badge--soon { background: rgba(67,151,176,0.15); border-color: rgba(67,151,176,0.35); color: var(--dc-teal); }

.dc-grid { display: grid; gap: 20px; }
.dc-grid--2 { grid-template-columns: repeat(2, 1fr); }
.dc-grid--3 { grid-template-columns: repeat(3, 1fr); }
.dc-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .dc-grid--2, .dc-grid--3, .dc-grid--4 { grid-template-columns: 1fr; } }

/* Header */
.dc-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,243,219,0.92);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dc-tr);
}
.dc-header.is-scrolled { border-color: var(--dc-ink-10); }
.dc-header__inner { max-width: 1280px; margin: 0 auto; padding: 14px 32px; display: flex; align-items: center; gap: 28px; }
.dc-logo { display: inline-flex; align-items: center; gap: 10px; }
.dc-logo__word { font-family: var(--dc-display); font-weight: 700; font-size: 22px; color: var(--dc-ink); letter-spacing: -0.02em; }
.dc-nav { display: flex; align-items: center; gap: 4px; flex: 1; margin-left: 12px; }
.dc-nav a { color: var(--dc-ink-70); font-size: 13.5px; font-weight: 500; padding: 8px 12px; border-radius: 999px; transition: all var(--dc-tr); }
.dc-nav a:hover, .dc-nav a.is-active { color: var(--dc-ink); background: var(--dc-ink-05); }
.dc-header__right { display: flex; align-items: center; gap: 12px; }
.dc-burger { display: none; }
@media (max-width: 1100px) {
  .dc-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--dc-ink); padding: 16px 24px; flex-direction: column; align-items: stretch; border-bottom: 1px solid rgba(250,243,219,0.1); z-index: 50; }
  .dc-nav.is-open { display: flex; }
  .dc-nav a { padding: 12px; color: rgba(250,243,219,0.75); }
  .dc-nav a:hover, .dc-nav a.is-active { color: var(--dc-yellow); background: rgba(250,243,219,0.08); }
  .dc-nav .dc-nav-drop__menu { display: none; }
  .dc-nav .dc-nav-drop.is-open .dc-nav-drop__menu { display: flex; flex-direction: column; padding: 4px 0 4px 16px; }
  .dc-nav .dc-nav-drop.is-open .dc-nav-drop__menu a { font-size: 13px; opacity: 0.7; }
  .dc-nav-drop { flex-direction: column; }
  .dc-burger { display: inline-flex; background: transparent; border: 1px solid var(--dc-ink-10); width: 40px; height: 40px; border-radius: 999px; align-items: center; justify-content: center; color: var(--dc-ink); flex-shrink: 0; margin-right: 8px; }
  .dc-header__right { gap: 8px; }
  .dc-header__right .dc-btn { display: none; }
}

/* Footer */
.dc-footer { background: var(--dc-ink); color: rgba(250,243,219,0.7); padding: 80px 0 36px; }
.dc-footer__cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(250,243,219,0.1); }
@media (max-width: 980px) { .dc-footer__cols { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .dc-footer__cols { grid-template-columns: 1fr; } }
.dc-footer__col h4 { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--dc-yellow); font-weight: 700; margin: 0 0 18px; }
.dc-footer__col a { display: block; font-size: 14px; color: rgba(250,243,219,0.7); text-decoration: none; padding: 6px 0; transition: color var(--dc-tr); }
.dc-footer__col a:hover { color: var(--dc-yellow); }
.dc-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 28px; font-size: 12px; color: rgba(250,243,219,0.45); flex-wrap: wrap; gap: 14px; }

/* Page hero */
.dc-page-hero { background: var(--dc-cream-warm); padding: 112px 0 88px; position: relative; overflow: hidden; }
.dc-page-hero h1 { font-family: var(--dc-display); font-weight: 700; font-size: clamp(40px, 5.2vw, 64px); line-height: 1.04; letter-spacing: -0.022em; margin: 18px 0 0; color: var(--dc-ink); max-width: 22ch; }
.dc-page-hero h1 .dc-accent { color: var(--dc-orange); font-weight: 600; }
.dc-page-hero .dc-lead { margin-top: 22px; }
.dc-page-hero .dc-cta-row { margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }

.dc-row-actions { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.dc-mt-sm { margin-top: 18px; }
.dc-mt    { margin-top: 28px; }
.dc-mt-lg { margin-top: 48px; }
.dc-mt-xl { margin-top: 72px; }

.dc-secheader { max-width: 760px; }
.dc-secheader .dc-h2 { margin-top: 18px; }
.dc-secheader .dc-lead { margin-top: 18px; }

/* Cards */
.dc-card {
  background: #fff; border: 1px solid var(--dc-ink-10);
  border-radius: 22px; padding: 28px; transition: all var(--dc-tr);
  display: flex; flex-direction: column; gap: 12px;
}
.dc-card:hover { border-color: var(--dc-orange); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(30,60,66,0.06); }
.dc-card h3 { font-family: var(--dc-display); font-size: 22px; margin: 0; color: var(--dc-ink); letter-spacing: -0.012em; line-height: 1.2; font-weight: 700; }
.dc-card p  { margin: 0; font-size: 14.5px; color: var(--dc-ink-70); line-height: 1.6; }
.dc-card__icon { width: 44px; height: 44px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; color: var(--dc-cream); background: var(--dc-orange); margin-bottom: 6px; }

/* Hero (home) */
.dc-herobig { position: relative; overflow: hidden; padding: 64px 0 88px;
  background: radial-gradient(1100px 500px at 12% 10%, rgba(250,196,97,0.16), transparent 60%),
              radial-gradient(900px 480px at 92% 80%, rgba(243,140,72,0.10), transparent 60%),
              #ffffff; }
.dc-herobig__inner { max-width: 1180px; margin: 0 auto; padding: 0 32px; position: relative; z-index: 2; text-align: center; }
.dc-herobig h1 { font-family: var(--dc-display); font-weight: 700; font-size: clamp(46px, 6.2vw, 80px); line-height: 1.02; letter-spacing: -0.028em; color: var(--dc-ink); margin: 22px auto 0; max-width: 18ch; }
.dc-herobig h1 .dc-accent { color: var(--dc-orange); font-weight: 600; }
.dc-herobig .dc-lead { margin: 24px auto 0; max-width: 60ch; font-size: 19px; color: var(--dc-ink-70); }
.dc-herobig__cta { display:flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 28px; }
.dc-herobig__proof { display: flex; gap: 28px; justify-content: center; flex-wrap: wrap; margin-top: 40px; font-size: 12.5px; color: var(--dc-ink-60); letter-spacing: 0.04em; }
.dc-herobig__proof span { display:inline-flex; align-items:center; gap:8px; }
.dc-herobig__proof i { width: 6px; height: 6px; border-radius: 50%; background: var(--dc-orange); display: inline-block; }
.dc-rings { position: absolute; pointer-events: none; width: 720px; height: 720px; left: 50%; top: 50%; transform: translate(-50%,-58%); z-index: 0; opacity: 0.55; }

/* Problem cards */
.dc-problem { background: var(--dc-cream-warm); border-radius: 22px; padding: 30px; border: 1px solid var(--dc-ink-05); display: flex; flex-direction: column; gap: 14px; }
.dc-problem__num { color: var(--dc-orange); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; }
.dc-problem h3 { font-family: var(--dc-display); font-size: 24px; margin: 0; color: var(--dc-ink); letter-spacing: -0.015em; font-weight: 700; }
.dc-problem p { margin: 0; color: var(--dc-ink-70); font-size: 15px; line-height: 1.6; }

/* Flow */
.dc-flow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 980px) { .dc-flow { grid-template-columns: 1fr; } }
.dc-flow__step { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 22px; padding: 26px; display: flex; flex-direction: column; gap: 12px; }
.dc-flow__step .num { font-size: 13px; font-weight: 700; letter-spacing: 0.1em; color: var(--dc-orange); }
.dc-flow__step h4 { font-family: var(--dc-display); font-weight: 700; font-size: 20px; color: var(--dc-ink); margin: 0; line-height: 1.2; letter-spacing: -0.012em; }
.dc-flow__step p { font-size: 14px; color: var(--dc-ink-70); margin: 0; line-height: 1.55; }
.dc-flow__sources { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }
.dc-flow__src { font-size: 11px; padding: 3px 9px; border-radius: 999px; background: var(--dc-ink-05); color: var(--dc-ink-70); font-weight: 500; }

/* Layers (5 camadas) */
.dc-layers { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 980px) { .dc-layers { grid-template-columns: 1fr; } }
.dc-layers__ring { position: relative; aspect-ratio: 1/1; max-width: 520px; margin: 0 auto; }
.dc-layers__ring svg { width: 100%; height: 100%; display: block; }
.dc-layers__list { display: flex; flex-direction: column; gap: 4px; }
.dc-layer { display: grid; grid-template-columns: 36px 1fr auto; gap: 16px; align-items: center; padding: 18px 6px; border-top: 1px solid var(--dc-ink-10); cursor: pointer; transition: background var(--dc-tr); }
.dc-layer:last-child { border-bottom: 1px solid var(--dc-ink-10); }
.dc-layer:hover, .dc-layer.is-active { background: var(--dc-ink-05); }
.dc-layer__dot { width: 16px; height: 16px; border-radius: 50%; border: 4px solid var(--dot, var(--dc-orange)); background: transparent; margin-left: 10px; }
.dc-layer.is-active .dc-layer__dot { background: var(--dot, var(--dc-orange)); }
.dc-layer__title { font-family: var(--dc-display); font-weight: 700; font-size: 18px; color: var(--dc-ink); letter-spacing: -0.01em; line-height: 1.2; }
.dc-layer__q { font-size: 13px; color: var(--dc-ink-60); margin-top: 4px; line-height: 1.45; }
.dc-layer__src { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dc-ink-45); white-space: nowrap; }

/* 5 layers — strip layout */
.dc-layers5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
@media (max-width: 1100px) { .dc-layers5 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .dc-layers5 { grid-template-columns: 1fr; } }
.dc-layer5 { position: relative; background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 18px; padding: 30px 22px 24px; display: flex; flex-direction: column; gap: 10px; min-height: 280px; transition: all var(--dc-tr); overflow: hidden; }
.dc-layer5:hover { transform: translateY(-4px); border-color: var(--c); box-shadow: 0 18px 40px rgba(30,60,66,0.08); }
.dc-layer5__bar { position: absolute; top: 0; left: 0; right: 0; height: 6px; background: var(--c); }
.dc-layer5__num { font-family: var(--dc-display); font-weight: 800; font-size: 13px; letter-spacing: 0.12em; color: var(--c); margin-top: 4px; }
.dc-layer5__title { font-family: var(--dc-display); font-weight: 700; font-size: 26px; letter-spacing: -0.015em; color: var(--dc-ink); margin: 0; line-height: 1.1; }
.dc-layer5__q { font-size: 14.5px; color: var(--dc-ink-70); line-height: 1.55; margin: 0; }
.dc-layer5__src { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--dc-ink-10); font-size: 11px; letter-spacing: 0.08em; color: var(--dc-ink-45); font-weight: 600; }

/* Module cards (Plataforma) */
.dc-modules { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (max-width: 880px) { .dc-modules { grid-template-columns: 1fr; } }
.dc-module { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 24px; padding: 28px; display: flex; flex-direction: column; gap: 18px; transition: all var(--dc-tr); }
.dc-module:hover { border-color: var(--dc-orange); transform: translateY(-3px); box-shadow: 0 18px 40px rgba(30,60,66,0.06); }
.dc-module__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.dc-module__head h3 { font-family: var(--dc-display); font-weight: 700; font-size: 24px; color: var(--dc-ink); margin: 0; letter-spacing: -0.012em; line-height: 1.15; }
.dc-module__head p { margin: 8px 0 0; color: var(--dc-ink-70); font-size: 14px; line-height: 1.55; }
.dc-module__chip { background: var(--dc-cream-warm); color: var(--dc-ink); font-size: 11px; font-weight: 700; letter-spacing: 0.06em; padding: 5px 11px; border-radius: 999px; text-transform: uppercase; border: 1px solid var(--dc-ink-05); flex-shrink: 0; }
.dc-module__mock { background: #FAF8F3; border-radius: 16px; padding: 16px; border: 1px solid var(--dc-ink-05); min-height: 180px; }
.dc-module__cta { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--dc-orange); font-weight: 700; align-self: flex-start; }

/* Audience */
.dc-aud { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 22px; padding: 30px; display: flex; flex-direction: column; gap: 16px; transition: all var(--dc-tr); position: relative; overflow: hidden; }
.dc-aud::before { content: ''; position: absolute; top: -40px; right: -40px; width: 140px; height: 140px; border-radius: 50%; background: var(--accent, var(--dc-orange)); opacity: 0.12; transition: transform var(--dc-tr); }
.dc-aud:hover { transform: translateY(-3px); border-color: var(--accent, var(--dc-orange)); box-shadow: 0 18px 40px rgba(30,60,66,0.06); }
.dc-aud:hover::before { transform: scale(1.4); }
.dc-aud__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--accent, var(--dc-orange)); display: flex; align-items: center; justify-content: center; color: var(--dc-cream); position: relative; z-index: 1; }
.dc-aud h3 { font-family: var(--dc-display); font-weight: 700; font-size: 22px; margin: 0; color: var(--dc-ink); position: relative; z-index: 1; letter-spacing: -0.012em; }
.dc-aud p { margin: 0; font-size: 14.5px; color: var(--dc-ink-70); line-height: 1.6; position: relative; z-index: 1; }
.dc-aud .cta { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; margin-top: auto; color: var(--accent, var(--dc-orange)); position: relative; z-index: 1; }

/* Final CTA */
.dc-final { background: var(--dc-ink); color: var(--dc-cream); position: relative; overflow: hidden; }
.dc-final h2 { color: var(--dc-cream); }
.dc-final h2 .dc-accent { color: var(--dc-yellow); }
.dc-final .dc-lead { color: rgba(250,243,219,0.78); }

.dc-blob { position: absolute; pointer-events: none; user-select: none; z-index: 0; }
.dc-symbol-text { font-family: var(--dc-display); font-weight: 700; font-size: 22px; color: var(--dc-cream); letter-spacing: -0.02em; }

/* Steps */
.dc-steps { display: grid; gap: 18px; }
.dc-step { display: grid; grid-template-columns: 80px 1fr; gap: 24px; align-items: start; padding: 24px 0; border-top: 1px solid var(--dc-ink-10); }
.dc-step:last-child { border-bottom: 1px solid var(--dc-ink-10); }
.dc-step__num { font-family: var(--dc-display); font-weight: 700; font-size: 48px; color: var(--dc-orange); line-height: 1; letter-spacing: -0.025em; }
.dc-step__body h3 { font-family: var(--dc-display); font-weight: 700; font-size: 22px; margin: 0; color: var(--dc-ink); }
.dc-step__body p { margin: 8px 0 0; color: var(--dc-ink-70); font-size: 15px; line-height: 1.65; }

/* Sources */
.dc-source { display: flex; gap: 18px; align-items: flex-start; background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 18px; padding: 22px; flex-direction: column; }
.dc-source__head { display: flex; gap: 14px; align-items: center; }
.dc-source__dot { width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-weight: 800; color: var(--dc-cream); }
.dc-source h4 { font-family: var(--dc-display); font-weight: 700; margin: 0; font-size: 18px; color: var(--dc-ink); }
.dc-source__src { font-size: 11px; color: var(--dc-ink-60); letter-spacing: 0.08em; text-transform: uppercase; }
.dc-source p { margin: 0; font-size: 14px; color: var(--dc-ink-70); line-height: 1.55; }
.dc-source ul { margin: 0; padding-left: 18px; font-size: 13.5px; color: var(--dc-ink-70); line-height: 1.6; }

/* FAQ */
.dc-faq__item { border-bottom: 1px solid var(--dc-ink-10); padding: 18px 0; }
.dc-faq__q { display: flex; justify-content: space-between; align-items: center; font-family: var(--dc-display); font-weight: 700; font-size: 18px; color: var(--dc-ink); cursor: pointer; gap: 16px; }
.dc-faq__q::after { content: '+'; font-size: 22px; color: var(--dc-orange); transition: transform var(--dc-tr); }
.dc-faq__item.is-open .dc-faq__q::after { transform: rotate(45deg); }
.dc-faq__a { display: none; font-size: 15px; color: var(--dc-ink-70); line-height: 1.7; margin-top: 10px; max-width: 70ch; }
.dc-faq__item.is-open .dc-faq__a { display: block; }

/* Form */
.dc-form { display: grid; gap: 16px; }
.dc-form__row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (max-width: 600px) { .dc-form__row { grid-template-columns: 1fr; } }
.dc-field { display: flex; flex-direction: column; gap: 6px; }
.dc-field label { font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--dc-ink-60); }
.dc-field input, .dc-field select, .dc-field textarea { padding: 12px 14px; border-radius: 12px; border: 1px solid var(--dc-ink-10); background: #fff; font-size: 14px; font-family: inherit; color: var(--dc-ink); outline: none; transition: border-color var(--dc-tr); }
.dc-field input:focus, .dc-field select:focus, .dc-field textarea:focus { border-color: var(--dc-orange); }

/* Stats strip */
.dc-stats { display: grid; grid-template-columns: repeat(4, 1fr); background: var(--dc-ink); color: var(--dc-cream); border-radius: 28px; overflow: hidden; }
.dc-stats__cell { padding: 32px 26px; border-right: 1px solid rgba(250,243,219,0.08); }
.dc-stats__cell:last-child { border-right: none; }
.dc-stats__num { font-family: var(--dc-display); font-weight: 800; font-size: 48px; line-height: 1; color: var(--dc-yellow); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.dc-stats__lbl { font-size: 12px; color: rgba(250,243,219,0.65); margin-top: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
@media (max-width: 980px) { .dc-stats { grid-template-columns: repeat(2, 1fr); } .dc-stats__cell { border-right: none; border-bottom: 1px solid rgba(250,243,219,0.08); } }

/* Anim entrance */
.dc-rise { opacity: 0; transform: translateY(20px); transition: opacity .6s ease-out, transform .6s ease-out; }
.dc-rise.is-in { opacity: 1; transform: translateY(0); }

/* Quote / pull */
.dc-pull { background: var(--dc-yellow); border-radius: 22px; padding: 30px 36px; font-family: var(--dc-display); font-weight: 700; font-size: clamp(20px, 2.4vw, 28px); line-height: 1.25; color: var(--dc-ink); letter-spacing: -0.012em; }

/* Editorial pull quote */
.dc-quote { max-width: 880px; margin: 0 auto; padding: 0 8px; display: grid; grid-template-columns: 1fr; gap: 32px; }
.dc-quote__mark { display: block; font-family: var(--dc-display); font-weight: 700; font-size: 96px; line-height: 0.7; color: var(--dc-orange); margin: 0 0 -8px -4px; }
.dc-quote__body { font-family: var(--dc-display); font-weight: 500; font-size: clamp(22px, 2.4vw, 30px); line-height: 1.35; letter-spacing: -0.014em; color: var(--dc-ink); margin: 0; text-wrap: pretty; }
.dc-quote__cite { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.dc-quote__rule { display: inline-block; width: 40px; height: 1px; background: var(--dc-ink-45); }
.dc-quote__who  { font-family: var(--dc-display); font-weight: 700; font-size: 14px; color: var(--dc-ink); letter-spacing: -0.005em; }
.dc-quote__role { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--dc-ink-60); }

/* Timeline */
.dc-timeline { display: grid; gap: 16px; }
.dc-timeline__item { display: grid; grid-template-columns: 130px 1fr; gap: 24px; padding: 22px 0; border-top: 1px solid var(--dc-ink-10); }
.dc-timeline__year { font-family: var(--dc-display); font-weight: 800; color: var(--dc-orange); font-size: 22px; letter-spacing: -0.01em; }
.dc-timeline__body h4 { font-family: var(--dc-display); font-weight: 700; font-size: 18px; margin: 0 0 6px; color: var(--dc-ink); }
@media (max-width: 600px) {
  .dc-timeline__item { grid-template-columns: 1fr; gap: 6px; }
  .dc-timeline__year { font-size: 18px; }
}

/* Person card */
.dc-person { background: var(--dc-cream-warm); border-radius: 18px; padding: 22px; display: flex; flex-direction: column; gap: 10px; }
.dc-person__avatar { width: 54px; height: 54px; border-radius: 50%; background: var(--dc-orange); color: var(--dc-cream); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 20px; }
.dc-person h4 { margin: 0; font-family: var(--dc-display); font-weight: 700; font-size: 17px; color: var(--dc-ink); }
.dc-person .role { font-size: 12px; color: var(--dc-orange); letter-spacing: 0.06em; text-transform: uppercase; font-weight: 700; }
.dc-person p { margin: 0; font-size: 13.5px; color: var(--dc-ink-70); line-height: 1.55; }

/* Logo strip — apoios e parceiros (placeholders tipográficos) */
.dc-logos { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.dc-logo-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 22px;
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 14px;
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 17px;
  letter-spacing: -0.005em;
  color: var(--logo-c, var(--dc-ink));
  min-height: 54px;
  transition: all var(--dc-tr);
}
.dc-logo-chip:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(30,60,66,0.06); border-color: var(--logo-c, var(--dc-ink-20)); }
.dc-logo-chip em {
  font-style: normal;
  opacity: 0.65;
  font-weight: 700;
}
.dc-logo-chip sup {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.6;
  vertical-align: super;
  margin-left: 4px;
}

/* Support block — apoio doClima (com label + descrição) */
.dc-support {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 40px;
  padding: 28px 0;
  border-top: 1px solid var(--dc-ink-10);
  align-items: start;
}
.dc-support:first-of-type { border-top: none; padding-top: 0; }
@media (max-width: 820px) { .dc-support { grid-template-columns: 1fr; gap: 16px; } }
.dc-support__label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dc-orange);
  font-weight: 700;
  padding-top: 4px;
}
.dc-support__body { display: flex; flex-direction: column; gap: 14px; }
.dc-support__body p { margin: 0; font-size: 15px; line-height: 1.6; color: var(--dc-ink-70); }

/* Article card (Inteligência climática) */
.dc-article { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 22px; overflow: hidden; display: flex; flex-direction: column; transition: all var(--dc-tr); }
.dc-article:hover { transform: translateY(-3px); border-color: var(--dc-orange); box-shadow: 0 14px 32px rgba(30,60,66,0.06); }
.dc-article__cover { aspect-ratio: 16/10; background: var(--dc-cream-warm); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.dc-article__body { padding: 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.dc-article__cat { font-size: 11px; color: var(--dc-orange); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; }
.dc-article h3 { font-family: var(--dc-display); font-weight: 700; font-size: 19px; margin: 0; color: var(--dc-ink); line-height: 1.25; letter-spacing: -0.01em; }
.dc-article p { margin: 0; font-size: 14px; color: var(--dc-ink-70); line-height: 1.55; }
.dc-article__meta { font-size: 12px; color: var(--dc-ink-60); margin-top: auto; padding-top: 10px; }

/* Use case */
.dc-usecase { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 22px; padding: 30px; display: flex; flex-direction: column; gap: 14px; border-top: 4px solid var(--accent, var(--dc-orange)); transition: all var(--dc-tr); }
.dc-usecase:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(30,60,66,0.06); }
.dc-usecase__role { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent, var(--dc-orange)); font-weight: 700; }
.dc-usecase h3 { font-family: var(--dc-display); font-weight: 700; font-size: 22px; margin: 0; color: var(--dc-ink); letter-spacing: -0.012em; line-height: 1.2; }
.dc-usecase p { margin: 0; font-size: 14.5px; color: var(--dc-ink-70); line-height: 1.6; }
.dc-usecase .dc-deliveries {
  padding-top: 14px;
  border-top: 1px dashed var(--dc-ink-10);
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--dc-ink-70);
}
.dc-usecase .dc-deliveries strong {
  display: block;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent, var(--dc-orange)) !important;
  font-weight: 700;
  margin-bottom: 6px;
}

/* Pipeline (metodologia) */
.dc-pipe { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 980px) { .dc-pipe { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .dc-pipe { grid-template-columns: 1fr; } }
.dc-pipe__step { background: #fff; border-radius: 16px; padding: 20px; border: 1px solid var(--dc-ink-10); position: relative; }
.dc-pipe__step .num { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--dc-orange); font-weight: 800; }
.dc-pipe__step h4 { font-family: var(--dc-display); font-weight: 700; font-size: 16px; margin: 6px 0; color: var(--dc-ink); }
.dc-pipe__step p { font-size: 13px; color: var(--dc-ink-70); margin: 0; line-height: 1.5; }

/* Press kit list */
.dc-press { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 880px) { .dc-press { grid-template-columns: 1fr; } }
.dc-press__item { background: #fff; border: 1px solid var(--dc-ink-10); border-radius: 18px; padding: 22px; display: flex; flex-direction: column; gap: 8px; }
.dc-press__item h4 { font-family: var(--dc-display); font-weight: 700; font-size: 17px; margin: 0; color: var(--dc-ink); }
.dc-press__item p { font-size: 13.5px; color: var(--dc-ink-70); margin: 0; }
.dc-press__item a { font-size: 13px; color: var(--dc-orange); font-weight: 700; margin-top: auto; }

/* Exhibit — capas de materiais entregues */
.dc-exhibit {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  align-items: start;
}
@media (max-width: 980px) { .dc-exhibit { grid-template-columns: 1fr; gap: 48px; max-width: 480px; margin-left: auto; margin-right: auto; } }

.dc-exhibit__item { margin: 0; display: flex; flex-direction: column; gap: 20px; }

.dc-exhibit__shelf {
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  background: var(--dc-shelf-bg, var(--dc-ink));
  aspect-ratio: 1 / 1.1;
  padding: 22px;
  box-sizing: border-box;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.04),
    0 2px 4px rgba(30,60,66,0.06),
    0 18px 38px -12px rgba(30,60,66,0.22),
    0 30px 60px -28px rgba(30,60,66,0.28);
  transform: translateY(0);
  transition: transform .35s ease, box-shadow .35s ease;
}
.dc-exhibit__shelf::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0) 38%);
  pointer-events: none;
}
.dc-exhibit__shelf img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.dc-exhibit__item:hover .dc-exhibit__shelf {
  transform: translateY(-6px);
  box-shadow:
    0 1px 0 rgba(0,0,0,0.04),
    0 4px 8px rgba(30,60,66,0.08),
    0 26px 50px -14px rgba(30,60,66,0.28),
    0 40px 80px -32px rgba(30,60,66,0.32);
}

.dc-exhibit__item figcaption { display: flex; flex-direction: column; gap: 8px; padding: 0 4px; }
.dc-exhibit__tag {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dc-teal);
  font-weight: 700;
}
.dc-exhibit__item h3 {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.012em;
  margin: 0;
  color: var(--dc-ink);
}
.dc-exhibit__item figcaption p {
  font-size: 14.5px;
  color: var(--dc-ink-70);
  line-height: 1.6;
  margin: 0;
}

.dc-exhibit__formats {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid var(--dc-ink-10);
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 32px;
  align-items: start;
}
@media (max-width: 720px) { .dc-exhibit__formats { grid-template-columns: 1fr; gap: 16px; } }
.dc-exhibit__formats-label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dc-ink-45);
  font-weight: 700;
  padding-top: 6px;
}
.dc-exhibit__formats ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
}
.dc-exhibit__formats li {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 999px;
  font-size: 13.5px;
  color: var(--dc-ink);
  font-weight: 500;
}

/* Source cards — fontes oficiais (metodologia) */
.dc-srcgrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (max-width: 980px) { .dc-srcgrid { grid-template-columns: 1fr; } }
.dc-srccard {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all var(--dc-tr);
}
.dc-srccard:hover { border-color: var(--mark-c, var(--dc-ink-20)); transform: translateY(-3px); box-shadow: 0 14px 30px rgba(30,60,66,0.06); }
.dc-srccard__mark {
  background: var(--mark-bg, var(--dc-paper));
  color: var(--mark-c, var(--dc-ink));
  padding: 28px 24px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 110px;
  border-bottom: 1px solid var(--dc-ink-10);
  position: relative;
}
.dc-srccard__wordmark {
  font-family: var(--dc-display);
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: 30px;
  line-height: 1;
  color: var(--mark-c, var(--dc-ink));
}
.dc-srccard__wordmark em {
  font-style: normal;
  color: var(--mark-c2, var(--mark-c));
  opacity: 0.65;
  font-weight: 700;
}
.dc-srccard__wordmark sup {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.65;
  vertical-align: super;
  margin-left: 6px;
}
.dc-srccard__body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 8px; }
.dc-srccard__tag { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mark-c, var(--dc-ink-60)); font-weight: 700; }
.dc-srccard__name { font-family: var(--dc-display); font-weight: 700; font-size: 19px; margin: 0; color: var(--dc-ink); letter-spacing: -0.01em; }
.dc-srccard__name small { display: block; font-size: 13px; color: var(--dc-ink-60); font-weight: 500; margin-top: 2px; letter-spacing: 0; }
.dc-srccard__body p { margin: 6px 0 0; font-size: 14px; line-height: 1.6; color: var(--dc-ink-70); }

/* Question cards — o que conseguimos responder */
.dc-qcard {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 18px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  transition: all var(--dc-tr);
}
.dc-qcard:hover { border-color: var(--dc-teal); transform: translateY(-3px); }
.dc-qcard::before {
  content: '?';
  position: absolute;
  top: 18px;
  right: 22px;
  font-family: var(--dc-display);
  font-size: 38px;
  font-weight: 800;
  color: var(--dc-orange);
  opacity: 0.18;
  line-height: 1;
}
.dc-qcard h3 {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 18px;
  margin: 0;
  color: var(--dc-ink);
  padding-right: 36px;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.dc-qcard__src {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dc-orange);
  font-weight: 700;
  margin-top: 2px;
}
.dc-qcard p { margin: 0; font-size: 14px; color: var(--dc-ink-70); line-height: 1.6; }

/* Flow diagram — 3 etapas */
.dc-flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 16px;
  align-items: stretch;
}
@media (max-width: 860px) { .dc-flow { grid-template-columns: 1fr; } .dc-flow__arrow { display: none; } }
.dc-flow__node {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 18px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dc-flow__node--accent { background: var(--dc-ink); color: var(--dc-cream); border-color: var(--dc-ink); }
.dc-flow__node--accent .dc-flow__lbl { color: var(--dc-yellow); }
.dc-flow__node--accent .dc-flow__body { color: rgba(250,243,219,0.85); }
.dc-flow__lbl { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--dc-orange); font-weight: 700; }
.dc-flow__title { font-family: var(--dc-display); font-weight: 700; font-size: 18px; margin: 2px 0 0; line-height: 1.25; letter-spacing: -0.01em; }
.dc-flow__body { font-size: 13px; color: var(--dc-ink-70); line-height: 1.5; margin-top: 4px; }
.dc-flow__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--dc-orange);
  font-weight: 700;
}

/* Dimension cards (5 dimensões analíticas) */
.dc-dimgrid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
}
.dc-dim { grid-column: span 2; }
.dc-dim:nth-child(4) { grid-column: span 3; }
.dc-dim:nth-child(5) { grid-column: span 3; }
@media (max-width: 980px) {
  .dc-dimgrid { grid-template-columns: 1fr 1fr; }
  .dc-dim, .dc-dim:nth-child(n) { grid-column: span 1; }
}
@media (max-width: 640px) {
  .dc-dimgrid { grid-template-columns: 1fr; }
}
.dc-dim {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 22px;
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  overflow: hidden;
  transition: all var(--dc-tr);
}
.dc-dim::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 6px;
  background: var(--dim-c, var(--dc-orange));
}
.dc-dim:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(30,60,66,0.08); border-color: var(--dim-c, var(--dc-ink-20)); }
.dc-dim__num {
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dim-c, var(--dc-orange));
}
.dc-dim__title {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 26px;
  margin: 0;
  color: var(--dc-ink);
  letter-spacing: -0.018em;
  line-height: 1.15;
}
.dc-dim__q {
  font-family: var(--dc-serif, var(--dc-display));
  font-style: italic;
  font-size: 15.5px;
  line-height: 1.45;
  color: var(--dc-ink-70);
  border-left: 3px solid var(--dim-c, var(--dc-orange));
  padding-left: 14px;
  margin: 0;
}
.dc-dim__sources {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
  padding-top: 16px;
  border-top: 1px dashed var(--dc-ink-10);
}
.dc-dim__src {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.dc-dim__src strong {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 14.5px;
  color: var(--dc-ink);
  letter-spacing: -0.005em;
}
.dc-dim__src span {
  font-size: 13px;
  color: var(--dc-ink-70);
  line-height: 1.5;
}
.dc-dim__why {
  margin-top: auto;
  padding-top: 14px;
  font-size: 13px;
  color: var(--dc-ink-60);
  line-height: 1.55;
  font-style: italic;
}

/* Cruzamentos analíticos */
.dc-crossgrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
@media (max-width: 900px) { .dc-crossgrid { grid-template-columns: 1fr; } }
.dc-cross {
  background: #fff;
  color: var(--dc-ink);
  border: 1px solid var(--dc-ink-10);
  border-radius: 22px;
  padding: 28px 30px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  overflow: hidden;
  transition: all var(--dc-tr);
}
.dc-cross:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(30,60,66,0.06); border-color: var(--cross-c, var(--dc-orange)); }
.dc-cross::before {
  content: '×';
  position: absolute;
  top: 14px;
  right: 22px;
  font-family: var(--dc-display);
  font-size: 84px;
  font-weight: 800;
  color: var(--cross-c, var(--dc-orange));
  opacity: 0.16;
  line-height: 1;
  pointer-events: none;
}
.dc-cross__title {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0;
  color: var(--cross-c, var(--dc-orange));
}
.dc-cross__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.dc-cross__chip {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 4px 11px;
  border-radius: 999px;
  background: var(--dc-paper);
  color: var(--cross-c, var(--dc-ink-70));
  border: 1px solid var(--dc-ink-10);
}
.dc-cross__q {
  font-family: var(--dc-serif, var(--dc-display));
  font-style: italic;
  font-size: 19px;
  line-height: 1.4;
  margin: 4px 0 0;
  color: var(--dc-ink);
  font-weight: 500;
  padding-right: 24px;
}

/* Source reference table */
.dc-srctable-wrap {
  overflow-x: auto;
  border-radius: 16px;
  border: 1px solid var(--dc-ink-10);
  background: #fff;
}
.dc-srctable {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--mon-mono, 'JetBrains Mono', 'DM Mono', ui-monospace, monospace);
  font-size: 13px;
}
.dc-srctable thead th {
  text-align: left;
  padding: 16px 18px;
  background: var(--dc-paper);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dc-ink-60);
  font-weight: 700;
  border-bottom: 1px solid var(--dc-ink-10);
  white-space: nowrap;
}
.dc-srctable tbody td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--dc-ink-05, rgba(30,60,66,0.05));
  vertical-align: top;
  color: var(--dc-ink);
  line-height: 1.5;
}
.dc-srctable tbody tr:last-child td { border-bottom: none; }
.dc-srctable tbody td:first-child { font-weight: 700; color: var(--dc-ink); }
.dc-srctable tbody td.dc-srctable__inst { color: var(--dc-ink-70); }
.dc-srctable tbody td.dc-srctable__cov { color: var(--dc-ink-70); white-space: nowrap; }
.dc-srctable tbody td a { color: var(--dc-orange); text-decoration: none; }
.dc-srctable tbody td a:hover { text-decoration: underline; }

/* ── Source data cards (metodologia) ─────────────────────────────── */
.dc-source-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
@media (max-width: 900px) { .dc-source-grid { grid-template-columns: 1fr; } }

.dc-source-card {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 18px;
  padding: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 168px 1fr;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.dc-source-card:hover {
  border-color: var(--dc-ink-20);
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(30,60,66,0.06);
}
@media (max-width: 640px) { .dc-source-card { grid-template-columns: 1fr; } }

.dc-source-card__mark {
  background: var(--mark-bg, var(--dc-teal));
  color: var(--mark-fg, var(--dc-cream));
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 18px;
  text-align: center;
  position: relative;
  min-height: 120px;
}
.dc-source-card__mark::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 18%, rgba(255,255,255,0.08) 0 22%, transparent 22%),
    radial-gradient(circle at 80% 80%, rgba(0,0,0,0.10) 0 18%, transparent 18%);
  pointer-events: none;
}
.dc-source-card__mark-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.dc-source-card__wordmark {
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 26px;
  letter-spacing: -0.02em;
  line-height: 1;
}
.dc-source-card__wordmark--small {
  font-size: 20px;
  letter-spacing: 0.02em;
}
.dc-source-card__wordmark .lite { font-weight: 400; opacity: 0.85; }
.dc-source-card__suffix {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.75;
  font-weight: 600;
  margin-top: 6px;
}

.dc-source-card__body {
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dc-source-card__body .label {
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dc-ink-45);
  font-weight: 700;
}
.dc-source-card__body h4 {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 19px;
  margin: 0;
  color: var(--dc-ink);
  letter-spacing: -0.012em;
  line-height: 1.25;
}
.dc-source-card__body p {
  margin: 0;
  font-size: 14px;
  color: var(--dc-ink-70);
  line-height: 1.55;
}

/* Diagram strip — Fontes → doClima → Saídas */
.dc-flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 0;
  align-items: stretch;
  border: 1px solid var(--dc-ink-10);
  border-radius: 22px;
  background: #fff;
  overflow: hidden;
}
@media (max-width: 860px) {
  .dc-flow { grid-template-columns: 1fr; }
  .dc-flow__arrow { display: none; }
  .dc-flow__cell { border-bottom: 1px solid var(--dc-ink-10); }
  .dc-flow__cell:last-child { border-bottom: none; }
}
.dc-flow__cell {
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.dc-flow__cell + .dc-flow__cell { /* unused on desktop, kept for safety */ }
.dc-flow__cell--center {
  background: var(--dc-ink);
  color: var(--dc-cream);
}
.dc-flow__cell .label {
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dc-ink-45);
  font-weight: 700;
}
.dc-flow__cell--center .label { color: rgba(250,243,219,0.55); }
.dc-flow__cell h4 {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 20px;
  margin: 0;
  letter-spacing: -0.012em;
  color: var(--dc-ink);
}
.dc-flow__cell--center h4 { color: var(--dc-yellow); }
.dc-flow__cell p {
  margin: 0;
  font-size: 13.5px;
  color: var(--dc-ink-70);
  line-height: 1.5;
}
.dc-flow__cell--center p { color: rgba(250,243,219,0.7); }
.dc-flow__arrow {
  align-self: center;
  padding: 0 6px;
  color: var(--dc-ink-45);
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 24px;
}

/* ── LANGUAGE TOGGLE ─────────────────────────────────────────────── */
.dc-langtoggle {
  background: transparent;
  border: 1px solid var(--dc-ink-20);
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--dc-ink-70);
  display: inline-flex;
  gap: 6px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.dc-langtoggle:hover {
  background: var(--dc-ink-05);
  border-color: var(--dc-ink-30);
  color: var(--dc-ink);
}
.dc-langtoggle span {
  opacity: 0.5;
  transition: all 0.2s ease;
}
.dc-langtoggle span.is-active {
  color: var(--dc-ink);
  opacity: 1;
}
.dc-langtoggle .dc-langtoggle-slash {
  opacity: 0.3;
}
/* doClima — "Como funciona" pipeline (3 etapas) — nova proposta
   Standalone class (.dc-pipeline) so it does NOT collide with the
   metodologia `.dc-flow` 5-cell layout that's also in site.css.        */

.dc-pipeline {
  display: grid;
  grid-template-columns: 1fr 28px 1fr 28px 1fr;
  gap: 0;
  align-items: stretch;
}
@media (max-width: 1000px) {
  .dc-pipeline { grid-template-columns: 1fr; gap: 18px; }
  .dc-pipeline__link { display: none; }
}

.dc-pipeline__step {
  --c: var(--dc-orange);
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  border-radius: 22px;
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: all var(--dc-tr);
  position: relative;
}
.dc-pipeline__step:hover {
  transform: translateY(-3px);
  border-color: var(--c);
  box-shadow: 0 18px 40px rgba(30,60,66,0.08);
}

/* Discrete doClima seal — removed per request */
.dc-pipeline__step::after {
  content: none;
}

/* Top band — “ETAPA 01” + verb */
.dc-pipeline__band {
  background: var(--c);
  color: #FAF3DB;
  padding: 18px 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
}
.dc-pipeline__band::after {
  content: '';
  position: absolute;
  right: -28px; bottom: -52px;
  width: 140px; height: 140px;
  border-radius: 50%;
  background: rgba(255,255,255,0.10);
}

/* Discrete doClima seal — removed from band; now lives on .dc-pipeline__step */
.dc-pipeline__etapa {
  font-family: var(--dc-display);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.85;
}
.dc-pipeline__verb {
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 42px;
  line-height: 1;
  letter-spacing: -0.025em;
  margin: 0;
  text-shadow: 0 1px 0 rgba(0,0,0,0.05);
}
.dc-pipeline__num {
  position: absolute;
  right: 18px; top: 14px;
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 56px;
  line-height: 1;
  color: rgba(255,255,255,0.32);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}

/* Body — title + description */
.dc-pipeline__body {
  padding: 22px 24px 4px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.dc-pipeline__title {
  font-family: var(--dc-display);
  font-weight: 700;
  font-size: 19px;
  margin: 0;
  color: var(--dc-ink);
  letter-spacing: -0.012em;
  line-height: 1.25;
}
.dc-pipeline__desc {
  font-size: 14.5px;
  color: var(--dc-ink-70);
  line-height: 1.6;
  margin: 0;
}

/* Source manifest — labelled list, not a chip cloud */
.dc-pipeline__manifest {
  margin-top: auto;
  padding: 18px 24px 22px;
  border-top: 1px dashed var(--dc-ink-10);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dc-pipeline__manifest-label {
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dc-ink-45);
  font-weight: 700;
}
.dc-pipeline__manifest-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dc-pipeline__manifest-list li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 13.5px;
  color: var(--dc-ink);
  font-weight: 500;
}
.dc-pipeline__manifest-list li::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--c);
  flex-shrink: 0;
  transform: translateY(-2px);
}

/* Connector — thin rule + chevron */
.dc-pipeline__link {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.dc-pipeline__link::before {
  content: '';
  position: absolute;
  left: 4px; right: 4px;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, var(--dc-ink-10), var(--dc-orange), var(--dc-ink-10));
}
.dc-pipeline__link::after {
  content: '';
  width: 10px; height: 10px;
  border-right: 1.5px solid var(--dc-orange);
  border-top: 1.5px solid var(--dc-orange);
  transform: rotate(45deg);
  background: transparent;
  position: relative;
  z-index: 1;
}

/* ── Tweaks parity ──────────────────────────────────────────────── */
/* The page-wide voice/mood tweaks should still hold here. */

/* Voice — when leader color isn't orange, swap step accent for the lead. */
.dc-site[data-voice="teal"]    .dc-pipeline__step:nth-child(1) { --c: var(--dc-teal); }
.dc-site[data-voice="amarelo"] .dc-pipeline__step:nth-child(1) { --c: #E0A53A; }
.dc-site[data-voice="teal"]    .dc-pipeline__link::before,
.dc-site[data-voice="teal"]    .dc-pipeline__link::after { border-color: var(--dc-teal); }
.dc-site[data-voice="amarelo"] .dc-pipeline__link::before,
.dc-site[data-voice="amarelo"] .dc-pipeline__link::after { border-color: #E0A53A; }

/* Editorial mood — flatten the cards into typographic blocks. */
.dc-site[data-mood="editorial"] .dc-pipeline__step {
  background: transparent;
  border: none;
  border-top: 1px solid var(--dc-ink);
  border-radius: 0;
  box-shadow: none !important;
}
.dc-site[data-mood="editorial"] .dc-pipeline__step:hover { transform: none; }
.dc-site[data-mood="editorial"] .dc-pipeline__band {
  background: transparent;
  color: var(--dc-ink);
  padding: 18px 0 14px;
}
.dc-site[data-mood="editorial"] .dc-pipeline__band::after { display: none; }
.dc-site[data-mood="editorial"] .dc-pipeline__step::after {
  /* Tone down further when cards are flat editorial blocks */
  opacity: 0.35;
}
.dc-site[data-mood="editorial"] .dc-pipeline__etapa { color: var(--c); opacity: 1; }
.dc-site[data-mood="editorial"] .dc-pipeline__verb { color: var(--dc-ink); text-shadow: none; }
.dc-site[data-mood="editorial"] .dc-pipeline__num { color: rgba(30,60,66,0.10); }
.dc-site[data-mood="editorial"] .dc-pipeline__body { padding: 0 0 12px; }
.dc-site[data-mood="editorial"] .dc-pipeline__manifest { padding: 14px 0 8px; }

/* Alerta mood — dark surfaces. */
.dc-site[data-mood="alerta"] .dc-pipeline__step {
  background: rgba(250,243,219,0.04);
  border-color: rgba(250,243,219,0.12);
}
.dc-site[data-mood="alerta"] .dc-pipeline__title { color: #FAF3DB; }
.dc-site[data-mood="alerta"] .dc-pipeline__desc  { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="alerta"] .dc-pipeline__manifest { border-top-color: rgba(250,243,219,0.12); }
.dc-site[data-mood="alerta"] .dc-pipeline__manifest-list li { color: rgba(250,243,219,0.85); }
.dc-site[data-mood="alerta"] .dc-pipeline__manifest-label { color: rgba(250,243,219,0.55); }

/* Estrutural — square the corners. */
.dc-site[data-geo="estrutural"] .dc-pipeline__step,
.dc-site[data-geo="estrutural"] .dc-pipeline__band { border-radius: 0; }
/* doClima — "A leitura doClima" section
   6-card grid + brand-symbol texture background for each card.
   Reuses .dc-layer5 card styles from site.css. */

.dc-layers6 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 1100px) { .dc-layers6 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .dc-layers6 { grid-template-columns: 1fr; } }

/* Brand symbol as a quiet background texture on every card */
.dc-layers6 .dc-layer5 {
  position: relative;
  isolation: isolate;
  min-height: 310px;
}
.dc-layers6 .dc-layer5::before {
  content: '';
  position: absolute;
  right: -56px;
  bottom: -64px;
  width: 260px;
  height: 260px;
  background: url('assets/simbolo.webp') no-repeat center / contain;
  opacity: 0.09;
  transform: rotate(-12deg);
  pointer-events: none;
  z-index: 0;
}
.dc-layers6 .dc-layer5 > * { position: relative; z-index: 1; }

/* Stagger the texture per card for organic variation */
.dc-layers6 .dc-layer5:nth-child(2)::before { right: auto; left: -60px; bottom: -50px; transform: rotate(18deg); }
.dc-layers6 .dc-layer5:nth-child(3)::before { right: -40px; top: 30%; bottom: auto; transform: rotate(-32deg); width: 220px; height: 220px; opacity: 0.07; }
.dc-layers6 .dc-layer5:nth-child(4)::before { right: auto; left: -70px; top: 40%; bottom: auto; transform: rotate(8deg); }
.dc-layers6 .dc-layer5:nth-child(5)::before { right: -50px; bottom: -70px; transform: rotate(-22deg); opacity: 0.18; filter: invert(1) brightness(2); }
.dc-layers6 .dc-layer5:nth-child(6)::before { right: -56px; bottom: -64px; transform: rotate(28deg); opacity: 0.16; }

/* When the card title is longer ("Histórico de impactos"), allow it room */
.dc-layers6 .dc-layer5__title { font-size: 24px; }

/* ── Tweaks parity (atmosfera / voz / geometria) ───────────────── */

/* Editorial mood — strip card-chrome, keep texture subtle */
.dc-site[data-mood="editorial"] .dc-layers6 .dc-layer5 {
  background: transparent;
  border: none;
  border-top: 1px solid var(--dc-ink);
  border-radius: 0;
  padding: 28px 0 4px;
  box-shadow: none !important;
}
.dc-site[data-mood="editorial"] .dc-layers6 .dc-layer5:hover { transform: none; box-shadow: none !important; }
.dc-site[data-mood="editorial"] .dc-layers6 .dc-layer5 .dc-layer5__bar { display: none; }
.dc-site[data-mood="editorial"] .dc-layers6 .dc-layer5::before { opacity: 0.05; }

/* Alerta mood — dark surfaces, texture leans cream */
.dc-site[data-mood="alerta"] .dc-layers6 .dc-layer5 {
  background: rgba(250,243,219,0.04);
  border-color: rgba(250,243,219,0.12);
}
.dc-site[data-mood="alerta"] .dc-layers6 .dc-layer5__title { color: #FAF3DB; }
.dc-site[data-mood="alerta"] .dc-layers6 .dc-layer5__q { color: rgba(250,243,219,0.78); }
.dc-site[data-mood="alerta"] .dc-layers6 .dc-layer5__src { color: rgba(250,243,219,0.6); border-top-color: rgba(250,243,219,0.12); }
.dc-site[data-mood="alerta"] .dc-layers6 .dc-layer5::before { opacity: 0.12; }

/* Estrutural geometry */
.dc-site[data-geo="estrutural"] .dc-layers6 .dc-layer5 { border-radius: 4px; }
/* doClima — Tweaks overrides
   Three expressive axes applied via body data-attrs:
     data-mood:  sereno | editorial | alerta
     data-voice: laranja | teal | amarelo
     data-geo:   macio  | estrutural
*/

/* ── VOZ CROMÁTICA — rotates the lead accent role ─────────────────── */
.dc-site[data-voice="laranja"]  { --dc-lead: var(--dc-orange); --dc-lead-soft: rgba(243,140,72,.18); --dc-lead-2: var(--dc-yellow); }
.dc-site[data-voice="teal"]     { --dc-lead: var(--dc-teal);   --dc-lead-soft: rgba(67,151,176,.18); --dc-lead-2: var(--dc-lime); }
.dc-site[data-voice="amarelo"]  { --dc-lead: #E0A53A;          --dc-lead-soft: rgba(250,196,97,.28); --dc-lead-2: var(--dc-orange); }

.dc-site[data-voice]:not([data-voice="laranja"]) .dc-eyebrow,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-h1 .dc-accent,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-h2 .dc-accent,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-flow__step .num,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-step__num,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-problem__num,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-aud .cta,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-module__cta,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-press__item a,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-faq__q::after,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-herobig__proof i,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-person .role,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-article__cat,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-timeline__year,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-pipe__step .num { color: var(--dc-lead); }

.dc-site[data-voice]:not([data-voice="laranja"]) .dc-btn--primary { background: var(--dc-lead); color: #FAF3DB; }
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-btn--primary:hover { background: var(--dc-ink); }
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-card__icon[style*="F38C48"],
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-card__icon { background: var(--dc-lead) !important; }
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-card:hover { border-color: var(--dc-lead); }
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-module:hover { border-color: var(--dc-lead); }
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-field input:focus,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-field select:focus,
.dc-site[data-voice]:not([data-voice="laranja"]) .dc-field textarea:focus { border-color: var(--dc-lead); }
.dc-site[data-voice="teal"]    .dc-pull { background: var(--dc-lead-2); }
.dc-site[data-voice="amarelo"] .dc-pull { background: var(--dc-yellow); }
.dc-site[data-voice="teal"]    .dc-stats__num { color: var(--dc-lead-2); }
.dc-site[data-voice="amarelo"] .dc-stats__num { color: var(--dc-yellow); }
.dc-site[data-voice="teal"]    .dc-final h2 .dc-accent { color: var(--dc-lead-2); }
.dc-site[data-voice="amarelo"] .dc-final h2 .dc-accent { color: var(--dc-yellow); }

/* ── ATMOSFERA — three different page moods ───────────────────────── */

/* EDITORIAL — paper-white, slimmer rules, more typographic, less blob */
.dc-site[data-mood="editorial"] { background: #F7F4ED !important; }
.dc-site[data-mood="editorial"] .dc-herobig {
  background: linear-gradient(180deg, #F2EDE0 0%, #F7F4ED 100%);
  padding: 80px 0 96px;
}
.dc-site[data-mood="editorial"] .dc-herobig .dc-blob { display: none; }
.dc-site[data-mood="editorial"] .dc-herobig h1 {
  font-weight: 600; letter-spacing: -0.035em;
}
.dc-site[data-mood="editorial"] .dc-herobig h1 .dc-accent { font-style: normal; font-weight: 500; }
.dc-site[data-mood="editorial"] .dc-sec { padding: 80px 0; }
.dc-site[data-mood="editorial"] .dc-sec[style*="cream-warm"],
.dc-site[data-mood="editorial"] .dc-sec[style*="cream"] { background: #EFE9D8 !important; }
.dc-site[data-mood="editorial"] .dc-card,
.dc-site[data-mood="editorial"] .dc-flow__step,
.dc-site[data-mood="editorial"] .dc-module,
.dc-site[data-mood="editorial"] .dc-aud,
.dc-site[data-mood="editorial"] .dc-article,
.dc-site[data-mood="editorial"] .dc-usecase,
.dc-site[data-mood="editorial"] .dc-source,
.dc-site[data-mood="editorial"] .dc-press__item {
  background: transparent;
  border: none;
  border-top: 1px solid rgba(30,60,66,0.18);
  border-radius: 0;
  padding: 28px 0 4px;
  box-shadow: none !important;
}
.dc-site[data-mood="editorial"] .dc-card:hover,
.dc-site[data-mood="editorial"] .dc-flow__step:hover,
.dc-site[data-mood="editorial"] .dc-module:hover,
.dc-site[data-mood="editorial"] .dc-aud:hover,
.dc-site[data-mood="editorial"] .dc-article:hover { transform: none; }
.dc-site[data-mood="editorial"] .dc-aud::before { display: none; }
.dc-site[data-mood="editorial"] .dc-problem {
  background: transparent;
  border-top: 2px solid var(--dc-ink);
  border-radius: 0;
  padding: 24px 0 0;
}
.dc-site[data-mood="editorial"] .dc-pull {
  background: transparent;
  border-top: 1px solid var(--dc-ink);
  border-bottom: 1px solid var(--dc-ink);
  border-radius: 0;
  padding: 36px 0;
  font-weight: 600;
}
.dc-site[data-mood="editorial"] .dc-stats {
  background: transparent;
  color: var(--dc-ink);
  border-radius: 0;
  border-top: 2px solid var(--dc-ink);
  border-bottom: 2px solid var(--dc-ink);
}
.dc-site[data-mood="editorial"] .dc-stats__cell { border-color: rgba(30,60,66,0.15); }
.dc-site[data-mood="editorial"] .dc-stats__num { color: var(--dc-ink); }
.dc-site[data-mood="editorial"] .dc-stats__lbl { color: rgba(30,60,66,0.6); }
.dc-site[data-mood="editorial"] .dc-layers__list .dc-layer { padding: 22px 6px; }
.dc-site[data-mood="editorial"] .dc-btn { border-radius: 0; }
.dc-site[data-mood="editorial"] .dc-btn--primary { background: var(--dc-ink); color: #F7F4ED; }
.dc-site[data-mood="editorial"] .dc-btn--primary:hover { background: var(--dc-lead, var(--dc-orange)); }

/* ALERTA — ink-dominant, urgent, dark hero with bright accents */
.dc-site[data-mood="alerta"] { background: #14282D !important; color: #F7EED0; }
.dc-site[data-mood="alerta"] .dc-h1,
.dc-site[data-mood="alerta"] .dc-h2,
.dc-site[data-mood="alerta"] .dc-h3,
.dc-site[data-mood="alerta"] .dc-card h3,
.dc-site[data-mood="alerta"] .dc-flow__step h4,
.dc-site[data-mood="alerta"] .dc-problem h3,
.dc-site[data-mood="alerta"] .dc-aud h3,
.dc-site[data-mood="alerta"] .dc-module__head h3,
.dc-site[data-mood="alerta"] .dc-layer__title,
.dc-site[data-mood="alerta"] .dc-secheader h2 { color: #FAF3DB; }
.dc-site[data-mood="alerta"] .dc-lead,
.dc-site[data-mood="alerta"] .dc-card p,
.dc-site[data-mood="alerta"] .dc-flow__step p,
.dc-site[data-mood="alerta"] .dc-problem p,
.dc-site[data-mood="alerta"] .dc-aud p,
.dc-site[data-mood="alerta"] .dc-module__head p,
.dc-site[data-mood="alerta"] .dc-layer__q { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="alerta"] .dc-herobig {
  background: radial-gradient(900px 500px at 20% 10%, rgba(243,140,72,0.22), transparent 60%),
              radial-gradient(800px 480px at 90% 90%, rgba(250,196,97,0.16), transparent 65%),
              #0E1F23;
}
.dc-site[data-mood="alerta"] .dc-sec[style*="cream-warm"],
.dc-site[data-mood="alerta"] .dc-sec[style*="cream"] { background: #19323A !important; }
.dc-site[data-mood="alerta"] .dc-card,
.dc-site[data-mood="alerta"] .dc-flow__step,
.dc-site[data-mood="alerta"] .dc-module,
.dc-site[data-mood="alerta"] .dc-aud,
.dc-site[data-mood="alerta"] .dc-article,
.dc-site[data-mood="alerta"] .dc-usecase,
.dc-site[data-mood="alerta"] .dc-source,
.dc-site[data-mood="alerta"] .dc-press__item {
  background: rgba(250,243,219,0.04);
  border-color: rgba(250,243,219,0.12);
}
.dc-site[data-mood="alerta"] .dc-card:hover,
.dc-site[data-mood="alerta"] .dc-flow__step:hover,
.dc-site[data-mood="alerta"] .dc-module:hover,
.dc-site[data-mood="alerta"] .dc-aud:hover { border-color: var(--dc-lead, var(--dc-orange)); box-shadow: 0 18px 40px rgba(0,0,0,0.35); }
.dc-site[data-mood="alerta"] .dc-problem {
  background: rgba(243,140,72,0.08);
  border: 1px solid rgba(243,140,72,0.18);
}
.dc-site[data-mood="alerta"] .dc-flow__src { background: rgba(250,243,219,0.08); color: rgba(250,243,219,0.7); }
.dc-site[data-mood="alerta"] .dc-pull { background: var(--dc-lead, var(--dc-orange)); color: var(--dc-ink); }
.dc-site[data-mood="alerta"] .dc-stats { background: rgba(0,0,0,0.35); }
.dc-site[data-mood="alerta"] .dc-final { background: #0A1518; }
.dc-site[data-mood="alerta"] .dc-btn--ghost { color: #FAF3DB; border-color: rgba(250,243,219,0.3); }
.dc-site[data-mood="alerta"] .dc-btn--ghost:hover { background: rgba(250,243,219,0.06); border-color: #FAF3DB; }
.dc-site[data-mood="alerta"] .dc-header {
  background: rgba(20,40,45,0.92);
}
.dc-site[data-mood="alerta"] .dc-header .dc-logo__word,
.dc-site[data-mood="alerta"] .dc-nav > a,
.dc-site[data-mood="alerta"] .dc-nav-drop > a { color: rgba(250,243,219,0.78); }
.dc-site[data-mood="alerta"] .dc-nav > a:hover,
.dc-site[data-mood="alerta"] .dc-nav > a.is-active,
.dc-site[data-mood="alerta"] .dc-nav-drop > a:hover,
.dc-site[data-mood="alerta"] .dc-nav-drop > a.is-active { color: #FAF3DB; background: rgba(250,243,219,0.08); }
.dc-site[data-mood="alerta"] .dc-nav-drop__menu a { color: var(--dc-ink); }
.dc-site[data-mood="alerta"] .dc-nav-drop__menu a:hover { color: var(--dc-orange); background: var(--dc-ink-05); }
.dc-site[data-mood="alerta"] .dc-layer { border-color: rgba(250,243,219,0.12); }
.dc-site[data-mood="alerta"] .dc-layer:hover,
.dc-site[data-mood="alerta"] .dc-layer.is-active { background: rgba(250,243,219,0.05); }
.dc-site[data-mood="alerta"] .dc-layer__src { color: rgba(250,243,219,0.5); }
.dc-site[data-mood="alerta"] .dc-module__chip { background: rgba(250,243,219,0.1); color: #FAF3DB; border-color: transparent; }
.dc-site[data-mood="alerta"] .dc-module__mock { background: rgba(0,0,0,0.25); border-color: rgba(250,243,219,0.08); }

/* ── GEOMETRIA — Macio (default) vs Estrutural ────────────────────── */
.dc-site[data-geo="estrutural"] {
  --dc-r-sm: 2px; --dc-r: 4px; --dc-r-lg: 6px;
}
.dc-site[data-geo="estrutural"] .dc-card,
.dc-site[data-geo="estrutural"] .dc-flow__step,
.dc-site[data-geo="estrutural"] .dc-module,
.dc-site[data-geo="estrutural"] .dc-aud,
.dc-site[data-geo="estrutural"] .dc-problem,
.dc-site[data-geo="estrutural"] .dc-pull,
.dc-site[data-geo="estrutural"] .dc-stats,
.dc-site[data-geo="estrutural"] .dc-article,
.dc-site[data-geo="estrutural"] .dc-usecase,
.dc-site[data-geo="estrutural"] .dc-source,
.dc-site[data-geo="estrutural"] .dc-press__item,
.dc-site[data-geo="estrutural"] .dc-person,
.dc-site[data-geo="estrutural"] .dc-module__mock,
.dc-site[data-geo="estrutural"] .dc-pipe__step { border-radius: 4px; }
.dc-site[data-geo="estrutural"] .dc-btn { border-radius: 4px; }
.dc-site[data-geo="estrutural"] .dc-badge,
.dc-site[data-geo="estrutural"] .dc-flow__src,
.dc-site[data-geo="estrutural"] .dc-nav a { border-radius: 3px; }
.dc-site[data-geo="estrutural"] .dc-card__icon,
.dc-site[data-geo="estrutural"] .dc-aud__icon { border-radius: 4px; }
.dc-site[data-geo="estrutural"] .dc-aud::before { border-radius: 0; width: 180px; height: 180px; }
.dc-site[data-geo="estrutural"] .dc-person__avatar,
.dc-site[data-geo="estrutural"] .dc-source__dot { border-radius: 4px; }
.dc-site[data-geo="estrutural"] .dc-burger { border-radius: 4px; }
.dc-site[data-geo="estrutural"] .dc-field input,
.dc-site[data-geo="estrutural"] .dc-field select,
.dc-site[data-geo="estrutural"] .dc-field textarea { border-radius: 3px; }
.dc-site[data-geo="estrutural"] .dc-layer__dot { border-radius: 2px; }
.dc-site[data-geo="estrutural"] .dc-herobig__proof i { border-radius: 0; }
/* ──────────────────────────────────────────────────────────────────
   doClima — HOPE PUNK
   Goodbye cream. Each section is a SOLID color block from the brand
   palette. Rhythm = deep → hot → cool → fresh → deep → joy → action.
   Built as an overlay on top of site.css via [data-mood="punk"].
   ────────────────────────────────────────────────────────────────── */

/* ── 0 · GLOBALS ─────────────────────────────────────────────────── */
.dc-site[data-mood="punk"] {
  background: var(--dc-ink) !important;
  color: var(--dc-cream);
}
html:has(body[data-mood="punk"]),
body.dc-site[data-mood="punk"] { background: var(--dc-ink) !important; }

/* Defeat the white-first background policy that lives in brand.css */
.dc-site[data-mood="punk"] [style*="background"] { background: transparent !important; }

.dc-site[data-mood="punk"] .dc-h1,
.dc-site[data-mood="punk"] .dc-h2,
.dc-site[data-mood="punk"] .dc-h3 { color: inherit; }

.dc-site[data-mood="punk"] .dc-lead { color: rgba(250,243,219,0.78); }

/* Reusable: a "stage" is any section the page paints a solid color. */
.dc-site[data-mood="punk"] section { position: relative; }

/* ── 1 · HEADER ──────────────────────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-header {
  background: rgba(30,60,66,0.78) !important;
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid rgba(250,243,219,0.08);
}
.dc-site[data-mood="punk"] .dc-header .dc-logo__word { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-nav > a,
.dc-site[data-mood="punk"] .dc-nav-drop > a { color: rgba(250,243,219,0.7); }
.dc-site[data-mood="punk"] .dc-nav > a:hover,
.dc-site[data-mood="punk"] .dc-nav > a.is-active,
.dc-site[data-mood="punk"] .dc-nav-drop > a:hover,
.dc-site[data-mood="punk"] .dc-nav-drop > a.is-active {
  color: var(--dc-yellow);
  background: rgba(250,196,97,0.10);
}
.dc-site[data-mood="punk"] .dc-nav-drop__menu a { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-nav-drop__menu a:hover { color: var(--dc-orange); background: var(--dc-ink-05); }
.dc-site[data-mood="punk"] .dc-burger { color: var(--dc-cream); border-color: rgba(250,243,219,0.18); }
.dc-site[data-mood="punk"] .dc-btn--ghost {
  color: var(--dc-cream);
  border-color: rgba(250,243,219,0.28);
}
.dc-site[data-mood="punk"] .dc-btn--ghost:hover {
  border-color: var(--dc-yellow);
  color: var(--dc-yellow);
  background: transparent;
}

/* ── 2 · HERO — deep ink + concentric symbol blast ───────────────── */
.dc-site[data-mood="punk"] .dc-herobig {
  background:
    radial-gradient(1200px 700px at 50% 38%, rgba(250,196,97,0.18), transparent 62%),
    radial-gradient(900px 600px at 88% 90%, rgba(243,140,72,0.18), transparent 65%),
    radial-gradient(700px 500px at 10% 100%, rgba(85,199,210,0.10), transparent 60%),
    var(--dc-ink) !important;
  padding: 110px 0 120px;
  isolation: isolate;
  overflow: hidden;
}

/* Kill the old soft blob images on the hero — they fight with the symbol. */
.dc-site[data-mood="punk"] .dc-herobig > .dc-blob { display: none !important; }

/* Concentric brand symbol as the hero protagonist */
.dc-site[data-mood="punk"] .dc-herobig::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 52%;
  width: min(960px, 92vw);
  aspect-ratio: 1/1;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, transparent 0 38px,
                #F38C48 38px 42px, transparent 42px 110px,
                #FAC461 110px 114px, transparent 114px 200px,
                #DDE390 200px 204px, transparent 204px 300px,
                #55C7D2 300px 304px, transparent 304px 400px,
                #4297B0 400px 404px, transparent 404px 100%);
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
  animation: punk-rings 28s linear infinite;
}
@keyframes punk-rings {
  0%   { transform: translate(-50%, -50%) rotate(0deg) scale(1); }
  50%  { transform: translate(-50%, -50%) rotate(180deg) scale(1.04); }
  100% { transform: translate(-50%, -50%) rotate(360deg) scale(1); }
}

.dc-site[data-mood="punk"] .dc-herobig__inner { color: var(--dc-cream) !important; }
.dc-site[data-mood="punk"] .dc-herobig h1 {
  color: var(--dc-cream) !important;
  font-weight: 800;
  letter-spacing: -0.035em;
  font-size: clamp(56px, 8vw, 116px);
  line-height: 0.96;
  max-width: 16ch;
  text-wrap: balance;
}
.dc-site[data-mood="punk"] .dc-herobig h1 .dc-accent { color: var(--dc-yellow); font-weight: 800; }
.dc-site[data-mood="punk"] .dc-herobig .dc-lead {
  color: rgba(250,243,219,0.82);
  font-size: 20px;
  max-width: 58ch;
}
.dc-site[data-mood="punk"] .dc-herobig__proof {
  color: var(--dc-yellow);
  margin-top: 56px;
  font-weight: 600;
  letter-spacing: 0.06em;
}
.dc-site[data-mood="punk"] .dc-herobig__proof i {
  background: var(--dc-yellow);
  box-shadow: 0 0 0 4px rgba(250,196,97,0.18);
}

/* Hero CTA — yellow on ink */
.dc-site[data-mood="punk"] .dc-herobig .dc-btn--primary {
  background: var(--dc-yellow);
  color: var(--dc-ink);
  border-radius: 4px;
  padding: 18px 30px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: 6px 6px 0 0 var(--dc-orange);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.dc-site[data-mood="punk"] .dc-herobig .dc-btn--primary:hover {
  background: var(--dc-cream);
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 0 var(--dc-orange);
}

/* Marquee under the hero — running manifesto strip */
.dc-site[data-mood="punk"] .dc-punk-marquee {
  background: var(--dc-orange);
  color: var(--dc-ink);
  padding: 18px 0;
  overflow: hidden;
  border-top: 2px solid var(--dc-ink);
  border-bottom: 2px solid var(--dc-ink);
  position: relative;
  z-index: 2;
}
.dc-site[data-mood="punk"] .dc-punk-marquee__track {
  display: inline-flex;
  gap: 56px;
  white-space: nowrap;
  animation: punk-marquee 38s linear infinite;
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.dc-site[data-mood="punk"] .dc-punk-marquee__track span { display: inline-flex; align-items: center; gap: 56px; }
.dc-site[data-mood="punk"] .dc-punk-marquee__track svg { flex-shrink: 0; }
@keyframes punk-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── 3 · PROBLEMA — orange block, ink type, brutalist cards ─────── */
.dc-site[data-mood="punk"] section.dc-sec[data-screen-label="Problema"],
.dc-site[data-mood="punk"] section.dc-sec.dc-punk-problema {
  background: var(--dc-orange) !important;
  color: var(--dc-ink);
  padding: 120px 0;
}
.dc-site[data-mood="punk"] .dc-punk-problema .dc-eyebrow { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-problema .dc-eyebrow::before { background: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-problema .dc-h2,
.dc-site[data-mood="punk"] .dc-punk-problema .dc-h2 .dc-accent { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-problema .dc-h2 .dc-accent {
  background: var(--dc-ink);
  color: var(--dc-yellow);
  padding: 0 14px 4px;
  border-radius: 4px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.dc-site[data-mood="punk"] .dc-punk-problema .dc-problem {
  background: var(--dc-ink) !important;
  color: var(--dc-cream);
  border: none;
  border-radius: 4px;
  padding: 36px 30px;
  position: relative;
  overflow: hidden;
}
.dc-site[data-mood="punk"] .dc-punk-problema .dc-problem__num {
  color: var(--dc-yellow);
  font-family: var(--dc-display);
  font-weight: 800;
  font-size: 56px;
  letter-spacing: -0.04em;
  text-transform: none;
}
.dc-site[data-mood="punk"] .dc-punk-problema .dc-problem h3 {
  color: var(--dc-cream);
  font-size: 26px;
  font-weight: 800;
}
.dc-site[data-mood="punk"] .dc-punk-problema .dc-problem p {
  color: rgba(250,243,219,0.76);
}

/* ── 4 · COMO FUNCIONA — teal block, cream cards stay readable ──── */
.dc-site[data-mood="punk"] section.dc-punk-pipeline {
  background: var(--dc-teal) !important;
  color: var(--dc-cream);
  padding: 120px 0;
  overflow: hidden;
}
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-eyebrow { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-eyebrow::before { background: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-h2 { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-h2 .dc-accent { color: var(--dc-yellow); }

.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__step {
  background: var(--dc-cream);
  border: none;
  border-radius: 6px;
  box-shadow: 8px 8px 0 0 rgba(30,60,66,0.45);
}
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__step:hover {
  transform: translate(-3px, -3px);
  box-shadow: 11px 11px 0 0 rgba(30,60,66,0.6);
}
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__band {
  background: var(--c);
  color: var(--dc-cream);
  padding: 22px 24px 26px;
}
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__verb { color: var(--dc-cream); font-size: 46px; font-weight: 800; }
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__num { color: rgba(250,243,219,0.4); font-size: 64px; }
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__link::before {
  background: linear-gradient(90deg, transparent, var(--dc-yellow), transparent);
}
.dc-site[data-mood="punk"] .dc-punk-pipeline .dc-pipeline__link::after { border-color: var(--dc-yellow); }

/* ── 5 · 9 CAMADAS — lime block, ink-on-light, color-blocked cards ─ */
.dc-site[data-mood="punk"] section.dc-punk-layers {
  background: var(--dc-lime) !important;
  color: var(--dc-ink);
  padding: 120px 0;
}
.dc-site[data-mood="punk"] .dc-punk-layers .dc-eyebrow { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-eyebrow::before { background: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-h2 { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-h2 .dc-accent { color: var(--dc-teal); font-weight: 800; }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-lead { color: rgba(30,60,66,0.78); }

.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5 {
  background: var(--dc-ink);
  color: var(--dc-cream);
  border: none;
  border-radius: 6px;
  box-shadow: 6px 6px 0 0 rgba(30,60,66,0.25);
  padding: 36px 24px 24px;
}
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5:hover {
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 0 rgba(30,60,66,0.35);
}
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5__bar { height: 8px; background: var(--c); }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5__num { color: var(--c); font-size: 14px; }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5__title { color: var(--dc-cream); font-weight: 800; font-size: 28px; }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5__q { color: rgba(250,243,219,0.78); }
.dc-site[data-mood="punk"] .dc-punk-layers .dc-layer5__src {
  border-top-color: rgba(250,243,219,0.15);
  color: var(--c);
}

/* ── 6 · AUDIENCES — deep ink anchor, color-coded glow cards ─────── */
.dc-site[data-mood="punk"] section.dc-punk-aud {
  background: var(--dc-ink) !important;
  color: var(--dc-cream);
  padding: 120px 0;
}
.dc-site[data-mood="punk"] .dc-punk-aud .dc-eyebrow { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-eyebrow::before { background: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-h2 { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-h2 .dc-accent { color: var(--dc-yellow); }

.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud {
  background: rgba(250,243,219,0.04);
  border: 1px solid rgba(250,243,219,0.10);
  border-radius: 6px;
  color: var(--dc-cream);
  transition: all var(--dc-tr);
}
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud:hover {
  background: var(--accent);
  color: var(--dc-ink);
  border-color: var(--accent);
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 0 rgba(0,0,0,0.4);
}
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud::before {
  background: var(--accent);
  opacity: 0.18;
  transition: all var(--dc-tr);
}
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud:hover::before { opacity: 0; }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud h3 { color: inherit; }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud p { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud:hover p { color: rgba(30,60,66,0.82); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud .cta { color: var(--accent); font-weight: 700; }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud:hover .cta { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-aud .dc-aud__icon {
  background: var(--accent);
  color: var(--dc-ink);
  border-radius: 4px;
}

/* ── 7 · QUOTE — yellow block, ink type ──────────────────────────── */
.dc-site[data-mood="punk"] section.dc-punk-quote {
  background: var(--dc-yellow) !important;
  color: var(--dc-ink);
  padding: 100px 0 110px;
  overflow: hidden;
}
.dc-site[data-mood="punk"] .dc-punk-quote .dc-quote__mark { color: var(--dc-ink); font-size: 132px; line-height: 0.7; }
.dc-site[data-mood="punk"] .dc-punk-quote .dc-quote__body {
  color: var(--dc-ink);
  font-size: clamp(24px, 2.6vw, 34px);
  font-weight: 600;
  letter-spacing: -0.018em;
}
.dc-site[data-mood="punk"] .dc-punk-quote .dc-quote__rule { background: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-quote .dc-quote__who { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-punk-quote .dc-quote__role { color: rgba(30,60,66,0.62); }
.dc-site[data-mood="punk"] .dc-punk-quote img { display: none !important; }

/* ── 8 · FINAL CTA — orange action block ─────────────────────────── */
.dc-site[data-mood="punk"] section.dc-final {
  background: var(--dc-orange) !important;
  color: var(--dc-ink);
  padding: 120px 0;
}
.dc-site[data-mood="punk"] .dc-final > img { display: none !important; }
.dc-site[data-mood="punk"] .dc-final .dc-eyebrow { color: var(--dc-ink) !important; }
.dc-site[data-mood="punk"] .dc-final .dc-eyebrow::before { background: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-final .dc-h2 { color: var(--dc-ink); }
.dc-site[data-mood="punk"] .dc-final .dc-h2 .dc-accent { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-final .dc-lead { color: rgba(30,60,66,0.78); }
.dc-site[data-mood="punk"] .dc-final .dc-btn--primary {
  background: var(--dc-ink);
  color: var(--dc-yellow);
  border-radius: 4px;
  box-shadow: 6px 6px 0 0 rgba(0,0,0,0.18);
  padding: 18px 30px;
  font-size: 15px;
  font-weight: 700;
}
.dc-site[data-mood="punk"] .dc-final .dc-btn--primary:hover {
  background: var(--dc-cream);
  color: var(--dc-ink);
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 0 rgba(0,0,0,0.22);
}
.dc-site[data-mood="punk"] .dc-final .dc-btn--ghost-cream {
  border-color: var(--dc-ink);
  color: var(--dc-ink);
}
.dc-site[data-mood="punk"] .dc-final .dc-btn--ghost-cream:hover {
  background: var(--dc-ink);
  color: var(--dc-yellow);
  border-color: var(--dc-ink);
}

/* ── 9 · FOOTER — keep ink, but cut the soft glow ────────────────── */
.dc-site[data-mood="punk"] .dc-footer { background: #0E1F23; border-top: 2px solid var(--dc-orange); }
.dc-site[data-mood="punk"] .dc-footer__col h4 { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-footer__col a:hover { color: var(--dc-orange); }

/* ── 10 · Cross-cutting punk details ─────────────────────────────── */
/* Eyebrow becomes a tighter chip-like accent on the punk page */
.dc-site[data-mood="punk"] .dc-eyebrow {
  font-weight: 700;
  letter-spacing: 0.18em;
}

/* All primary buttons get the brutalist offset-shadow treatment */
.dc-site[data-mood="punk"] .dc-btn--primary {
  border-radius: 4px;
}

/* Selection */
.dc-site[data-mood="punk"] ::selection { background: var(--dc-yellow); color: var(--dc-ink); }

/* Small screens — keep impact, tighten rhythm */
@media (max-width: 720px) {
  .dc-site[data-mood="punk"] .dc-herobig { padding: 80px 0 80px; }
  .dc-site[data-mood="punk"] section { padding-left: 0; padding-right: 0; }
  .dc-site[data-mood="punk"] .dc-herobig h1 { font-size: clamp(42px, 11vw, 64px); }
  .dc-site[data-mood="punk"] .dc-punk-marquee__track { font-size: 16px; gap: 32px; }
  .dc-site[data-mood="punk"] .dc-punk-marquee__track span { gap: 32px; }
}

/* ==================================================================
   PUNK · PART II — ALL INTERIOR PAGES
   Per-page lead color + alternating section rhythm.
   ================================================================== */

/* Per-page lead color (matches the audience colors used on home) */
.dc-site[data-mood="punk"]                          { --punk-lead: var(--dc-orange); --punk-lead-2: var(--dc-yellow); --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="governos"]    { --punk-lead: #397F94; --punk-lead-2: #DDE390; --punk-on-lead: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="imprensa"]    { --punk-lead: #F38C48; --punk-lead-2: #FAC461; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="empresas"]    { --punk-lead: #4297B0; --punk-lead-2: #99D5B1; --punk-on-lead: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="organizacoes"]{ --punk-lead: #FAC461; --punk-lead-2: #DDE390; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="sobre"]       { --punk-lead: #55C7D2; --punk-lead-2: #FCDD76; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="metodologia"] { --punk-lead: #4297B0; --punk-lead-2: #DDE390; --punk-on-lead: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="inteligencia"]{ --punk-lead: #DDE390; --punk-lead-2: #FCDD76; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="diagnostico"] { --punk-lead: #F38C48; --punk-lead-2: #FAC461; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="contato"]     { --punk-lead: #FCDD76; --punk-lead-2: #F8AA4E; --punk-on-lead: var(--dc-ink); }
.dc-site[data-mood="punk"][data-page="voce-sabia"]  { --punk-lead: #E04E2C; --punk-lead-2: #FAC461; --punk-on-lead: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="plataforma"]  { --punk-lead: #F38C48; --punk-lead-2: #FAC461; --punk-on-lead: var(--dc-cream); }

/* Você Sabia? page — colored hero to match the other pages */
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero {
  background: var(--punk-lead) !important;
}
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero h1 { color: var(--punk-on-lead); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero h1 .gn-accent { color: var(--dc-yellow); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__lead { color: rgba(250,243,219,0.88); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__counter-num { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__counter-lbl { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__counters { border-top-color: rgba(250,243,219,0.22); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__counter-num > span { color: rgba(250,243,219,0.55) !important; }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-hero__tag { background: var(--dc-ink); color: var(--dc-cream); }

/* Você Sabia? — apply vivid section colors using each section's own --gn-c */
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm {
  background: var(--gn-c, var(--punk-lead)) !important;
  color: var(--dc-cream);
}
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-sectitle,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-sectitle,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-sectitle,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper h2,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream h2,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm h2,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__head,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__head,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__head { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-sectitle .gn-emph,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-sectitle .gn-emph,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-sectitle .gn-emph,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-quote p .gn-emph,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-quote p .gn-emph,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-quote p .gn-emph { color: var(--dc-yellow); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-sec__sub,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-sec__sub,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-sec__sub,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__caption,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__caption,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__caption { color: rgba(250,243,219,0.85); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-eyebrow,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-eyebrow,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-eyebrow { color: var(--dc-yellow); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__source,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__source,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__source { color: rgba(250,243,219,0.6); }

/* The flagship giant numbers: override the colored variants on colored bgs */
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__num { color: var(--dc-cream) !important; }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__num--yellow,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__num--yellow,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__num--yellow { -webkit-text-stroke: 1.5px var(--dc-cream); color: transparent !important; }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-flagship__rule,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-flagship__rule,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-flagship__rule { background: var(--dc-yellow); }

/* Cards become translucent cream overlays on colored bgs */
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card {
  background: rgba(250,243,219,0.08);
  border-color: rgba(250,243,219,0.20);
}
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card__num { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card__num .gn-unit-sm,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card__num .gn-unit-sm,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card__num .gn-unit-sm { color: rgba(250,243,219,0.6); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card__head,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card__head,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card__head { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card__caption,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card__caption,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card__caption { color: rgba(250,243,219,0.78); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-card__tag,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-card__tag,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-card__tag { color: var(--dc-yellow); }

/* Quote pull-block + compare */
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-quote,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-quote,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-quote { border-color: rgba(250,243,219,0.20); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-quote p,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-quote p,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-quote p { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-quote__tag,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-quote__tag,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-quote__tag { background: var(--dc-ink); color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-compare,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-compare,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-compare {
  background: rgba(250,243,219,0.08);
  border-color: rgba(250,243,219,0.20);
}
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-compare__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-compare__num,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-compare__num { color: var(--dc-cream); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-compare__num--right,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-compare__num--right,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-compare__num--right { color: var(--dc-yellow); }
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--paper .gn-compare__lbl,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--cream .gn-compare__lbl,
.dc-site[data-mood="punk"][data-page="voce-sabia"] .gn-sec--warm .gn-compare__lbl { color: rgba(250,243,219,0.72); }

/* Strip the white-first inline overrides on punk pages — paint freely */
.dc-site[data-mood="punk"] section[style*="background"] { background: transparent !important; }

/* ── PAGE HERO ─────────────────────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-page-hero {
  background: var(--punk-lead) !important;
  color: var(--punk-on-lead);
  padding: 140px 0 100px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.dc-site[data-mood="punk"] .dc-page-hero::before {
  /* concentric brand symbol — echoes the home hero */
  content: "";
  position: absolute;
  right: -160px; top: 50%;
  width: 720px; aspect-ratio: 1/1;
  transform: translateY(-50%);
  background: radial-gradient(circle, transparent 0 30px,
    currentColor 30px 32px, transparent 32px 84px,
    currentColor 84px 86px, transparent 86px 152px,
    currentColor 152px 154px, transparent 154px 230px,
    currentColor 230px 232px, transparent 232px 320px,
    currentColor 320px 322px, transparent 322px 100%);
  opacity: 0.10;
  pointer-events: none;
  z-index: 0;
  animation: punk-rings 32s linear infinite;
}
.dc-site[data-mood="punk"] .dc-page-hero > .dc-blob,
.dc-site[data-mood="punk"] .dc-page-hero > img.dc-blob { display: none !important; }
.dc-site[data-mood="punk"] .dc-page-hero .dc-wrap { position: relative; z-index: 1; }
.dc-site[data-mood="punk"] .dc-page-hero h1 {
  color: var(--punk-on-lead);
  font-weight: 800;
  letter-spacing: -0.035em;
  font-size: clamp(48px, 6vw, 88px);
  line-height: 0.98;
  max-width: 18ch;
  text-wrap: balance;
}
.dc-site[data-mood="punk"] .dc-page-hero h1 .dc-accent {
  color: var(--punk-on-lead);
  background: var(--punk-lead-2);
  padding: 0 14px 4px;
  border-radius: 6px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  font-weight: 800;
}
/* When the page-hero bg is dark-cream-text, flip the accent block style */
.dc-site[data-mood="punk"][data-page="governos"] .dc-page-hero h1 .dc-accent,
.dc-site[data-mood="punk"][data-page="empresas"] .dc-page-hero h1 .dc-accent,
.dc-site[data-mood="punk"][data-page="metodologia"] .dc-page-hero h1 .dc-accent {
  background: var(--punk-lead-2);
  color: var(--dc-ink);
}
.dc-site[data-mood="punk"] .dc-page-hero .dc-eyebrow {
  color: var(--punk-on-lead) !important;
  opacity: 0.78;
  font-weight: 800;
  letter-spacing: 0.18em;
}
.dc-site[data-mood="punk"] .dc-page-hero .dc-eyebrow::before { background: currentColor; }
.dc-site[data-mood="punk"] .dc-page-hero .dc-lead {
  color: var(--punk-on-lead);
  opacity: 0.82;
  max-width: 60ch;
}
/* Page-hero CTAs — brutalist offset */
.dc-site[data-mood="punk"] .dc-page-hero .dc-btn--primary {
  background: var(--dc-ink);
  color: var(--dc-yellow);
  border-radius: 4px;
  padding: 16px 28px;
  font-weight: 700;
  box-shadow: 6px 6px 0 0 rgba(0,0,0,0.18);
}
.dc-site[data-mood="punk"][data-page="sobre"] .dc-page-hero .dc-btn--primary,
.dc-site[data-mood="punk"][data-page="organizacoes"] .dc-page-hero .dc-btn--primary,
.dc-site[data-mood="punk"][data-page="inteligencia"] .dc-page-hero .dc-btn--primary,
.dc-site[data-mood="punk"][data-page="contato"] .dc-page-hero .dc-btn--primary,
.dc-site[data-mood="punk"][data-page="diagnostico"] .dc-page-hero .dc-btn--primary,
.dc-site[data-mood="punk"][data-page="imprensa"] .dc-page-hero .dc-btn--primary { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-page-hero .dc-btn--primary:hover {
  background: var(--dc-cream);
  color: var(--dc-ink);
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 0 rgba(0,0,0,0.22);
}
.dc-site[data-mood="punk"] .dc-page-hero .dc-btn--ghost {
  border-color: var(--punk-on-lead);
  color: var(--punk-on-lead);
  background: transparent;
  border-radius: 4px;
}
.dc-site[data-mood="punk"] .dc-page-hero .dc-btn--ghost:hover {
  background: var(--punk-on-lead);
  color: var(--punk-lead);
  border-color: var(--punk-on-lead);
}

/* ── SECTION RHYTHM (alternating ink / lead-2) ─────────────────── */
/* Section index: 1 = hero, then alternate ink / lead-2.
   Last section that is .dc-final overrides to orange. */
.dc-site[data-mood="punk"] .dc-sec:not(.dc-final):not(.dc-page-hero) {
  position: relative;
  z-index: 0;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]),
.dc-site[data-mood="punk"] section.dc-sec[data-screen-label="A leitura doClima"] {
  /* even sections — INK */
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) {
  background: var(--dc-ink) !important;
  color: var(--dc-cream);
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) {
  background: var(--punk-lead-2) !important;
  color: var(--dc-ink);
}

/* Default text color & eyebrows on each section type */
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-eyebrow {
  color: var(--dc-yellow) !important;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-eyebrow::before { background: var(--dc-yellow); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2,
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h3 { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2 .dc-accent { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-lead { color: rgba(250,243,219,0.78); }

.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-eyebrow { color: var(--dc-ink) !important; }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-eyebrow::before { background: var(--dc-ink); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2,
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h3 { color: var(--dc-ink); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2 .dc-accent { color: var(--dc-orange); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-lead { color: rgba(30,60,66,0.78); }

/* Override the home page's hand-crafted section colors to dominate */
.dc-site[data-mood="punk"] .dc-punk-problema,
.dc-site[data-mood="punk"] .dc-punk-pipeline,
.dc-site[data-mood="punk"] .dc-punk-layers,
.dc-site[data-mood="punk"] .dc-punk-aud,
.dc-site[data-mood="punk"] .dc-punk-quote { /* keep their explicit colors; nth-of-type rule still cascades correctly */ }

/* ── CARDS — adapt to surrounding bg ───────────────────────────── */
/* On INK sections (even) — cards become subtle cream surfaces */
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card, .dc-flow__step, .dc-module, .dc-aud, .dc-usecase, .dc-source,
  .dc-press__item, .dc-article, .dc-pipe__step, .dc-srccard,
  .dc-source-card, .dc-flow__cell, .dc-source__head, .dc-qcard,
  .dc-dim, .dc-cross, .dc-person, .dc-problem
) {
  background: rgba(250,243,219,0.05) !important;
  border: 1px solid rgba(250,243,219,0.12);
  border-radius: 6px;
  color: var(--dc-cream);
  box-shadow: none;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card h3, .dc-flow__step h4, .dc-module__head h3, .dc-aud h3,
  .dc-usecase h3, .dc-press__item h4, .dc-article h3, .dc-pipe__step h4,
  .dc-srccard__name, .dc-qcard h3, .dc-dim__title, .dc-cross__title,
  .dc-person h4, .dc-problem h3, .dc-source h4
) { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card p, .dc-flow__step p, .dc-module__head p, .dc-aud p,
  .dc-usecase p, .dc-press__item p, .dc-article p, .dc-pipe__step p,
  .dc-srccard__body p, .dc-qcard p, .dc-dim__q, .dc-cross__q,
  .dc-person p, .dc-problem p, .dc-source p, .dc-source ul
) { color: rgba(250,243,219,0.72); }

/* On LEAD-2 sections (odd) — cards become deep ink boxes (high contrast) */
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card, .dc-flow__step, .dc-module, .dc-aud, .dc-usecase, .dc-source,
  .dc-press__item, .dc-article, .dc-pipe__step, .dc-srccard,
  .dc-source-card, .dc-flow__cell, .dc-qcard,
  .dc-dim, .dc-cross, .dc-person, .dc-problem
) {
  background: var(--dc-ink) !important;
  border: none !important;
  border-radius: 6px;
  color: var(--dc-cream);
  box-shadow: 6px 6px 0 0 rgba(30,60,66,0.30) !important;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card, .dc-flow__step, .dc-module, .dc-aud, .dc-usecase, .dc-source,
  .dc-press__item, .dc-article, .dc-pipe__step, .dc-dim, .dc-cross, .dc-qcard, .dc-problem
):hover {
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 0 rgba(30,60,66,0.42) !important;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card h3, .dc-flow__step h4, .dc-module__head h3, .dc-aud h3,
  .dc-usecase h3, .dc-press__item h4, .dc-article h3, .dc-pipe__step h4,
  .dc-srccard__name, .dc-qcard h3, .dc-dim__title, .dc-cross__title,
  .dc-person h4, .dc-problem h3, .dc-source h4
) { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(
  .dc-card p, .dc-flow__step p, .dc-module__head p, .dc-aud p,
  .dc-usecase p, .dc-press__item p, .dc-article p, .dc-pipe__step p,
  .dc-srccard__body p, .dc-qcard p, .dc-dim__q, .dc-cross__q,
  .dc-person p, .dc-problem p, .dc-source p, .dc-source ul
) { color: rgba(250,243,219,0.78); }

/* Strong accent strokes (dc-dim has ::before color bar, dc-cross has X) */
.dc-site[data-mood="punk"] .dc-dim::before { background: var(--punk-lead); }
.dc-site[data-mood="punk"] .dc-cross::before { color: var(--punk-lead); opacity: 0.4; }
.dc-site[data-mood="punk"] .dc-qcard::before { color: var(--punk-lead); opacity: 0.5; }
.dc-site[data-mood="punk"] .dc-usecase { border-top: 6px solid var(--punk-lead) !important; }
.dc-site[data-mood="punk"] .dc-usecase__role { color: var(--punk-lead) !important; }

/* dc-dim cards become deep ink boxes in punk mode — fix legibility of source labels */
.dc-site[data-mood="punk"] .dc-dim__src strong { color: var(--dc-cream); }
.dc-site[data-mood="punk"] .dc-dim__src span { color: rgba(250,243,219,0.78); }
.dc-site[data-mood="punk"] .dc-dim__why { color: rgba(250,243,219,0.72); border-top-color: rgba(250,243,219,0.18); }
.dc-site[data-mood="punk"] .dc-dim__num { color: var(--dc-yellow); }

/* Infrastructure section — keep dark ink bg (excluded from nth-of-type rotation) */
.dc-site[data-mood="punk"] .dc-punk-infra { background: var(--dc-ink) !important; }
.dc-site[data-mood="punk"] .dc-press__item a { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] .dc-step__num { color: var(--punk-lead); }
.dc-site[data-mood="punk"] .dc-timeline__year { color: var(--punk-lead); }
.dc-site[data-mood="punk"] .dc-faq__q::after { color: var(--punk-lead); }

/* Inline-styled accent spans inside h2 — normalize when on ink sections */
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2 span[style*="color"] { color: var(--dc-yellow) !important; }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-h2 span[style*="color"] { color: var(--dc-orange) !important; }

/* ── FORM (contato) ────────────────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-field input,
.dc-site[data-mood="punk"] .dc-field select,
.dc-site[data-mood="punk"] .dc-field textarea {
  background: rgba(250,243,219,0.05);
  border: 1px solid rgba(250,243,219,0.18);
  color: var(--dc-cream);
  border-radius: 4px;
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-field input,
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-field select,
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-field textarea {
  background: var(--dc-ink);
  border-color: rgba(250,243,219,0.18);
  color: var(--dc-cream);
}
.dc-site[data-mood="punk"] .dc-field input:focus,
.dc-site[data-mood="punk"] .dc-field select:focus,
.dc-site[data-mood="punk"] .dc-field textarea:focus { border-color: var(--punk-lead) !important; }
.dc-site[data-mood="punk"] .dc-field label { color: rgba(250,243,219,0.65); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-field label { color: rgba(250,243,219,0.78); }

/* ── FORM on light background (diagnóstico white card) ─────────── */
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field input,
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field select,
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field textarea {
  background: #fff;
  border: 1px solid var(--dc-ink-10);
  color: var(--dc-ink);
}
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field select:focus,
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field input:focus,
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field textarea:focus {
  border-color: var(--dc-orange);
}
.dc-site[data-mood="punk"] .dc-form[style*="background:#fff"] .dc-field label { color: rgba(250,243,219, 0.78); }

/* ── ASIDE cards (diagnóstico right column) ─────────────────────── */
/* Punk mood strips inline backgrounds → cards sit on dark section */
.dc-site[data-mood="punk"][data-page="diagnostico"] aside li {
  color: rgba(250, 243, 219, 0.78) !important;
}
.dc-site[data-mood="punk"][data-page="diagnostico"] aside p {
  color: rgba(250, 243, 219, 0.72) !important;
}
.dc-site[data-mood="punk"][data-page="diagnostico"] aside h3 {
  color: var(--dc-cream) !important;
}

/* ── EXHIBIT (entregas — capas de materiais) ───────────────────── */
.dc-site[data-mood="punk"] .dc-exhibit__shelf { box-shadow: 8px 8px 0 0 rgba(30,60,66,0.32) !important; border-radius: 4px; }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__item h3 { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__item figcaption p { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__tag { color: var(--dc-yellow); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__formats {
  border-top-color: rgba(250,243,219,0.15);
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__formats li {
  background: rgba(250,243,219,0.08);
  border-color: rgba(250,243,219,0.18);
  color: var(--dc-cream);
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-exhibit__formats-label { color: rgba(250,243,219,0.55); }

/* ── TABLE (sources) ───────────────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-srctable-wrap {
  background: var(--dc-ink) !important;
  border-color: rgba(250,243,219,0.12) !important;
  border-radius: 6px;
}
.dc-site[data-mood="punk"] .dc-srctable thead th {
  background: rgba(0,0,0,0.25);
  color: var(--dc-yellow);
  border-bottom-color: rgba(250,243,219,0.18);
}
.dc-site[data-mood="punk"] .dc-srctable tbody td { color: var(--dc-cream); border-bottom-color: rgba(250,243,219,0.10); }
.dc-site[data-mood="punk"] .dc-srctable tbody td.dc-srctable__inst,
.dc-site[data-mood="punk"] .dc-srctable tbody td.dc-srctable__cov { color: rgba(250,243,219,0.72); }
.dc-site[data-mood="punk"] .dc-srctable tbody td a { color: var(--punk-lead-2); }

/* ── FAQ items ─────────────────────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-faq__item { border-bottom-color: rgba(250,243,219,0.18); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-faq__item { border-bottom-color: rgba(30,60,66,0.18); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-faq__q { color: var(--dc-ink); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-faq__a { color: rgba(30,60,66,0.78); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-faq__q { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) .dc-faq__a { color: rgba(250,243,219,0.78); }

/* ── TIMELINE / STEPS ──────────────────────────────────────────── */
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(.dc-step, .dc-timeline__item) {
  border-top-color: rgba(250,243,219,0.18);
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n+1):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(.dc-step, .dc-timeline__item) {
  border-top-color: rgba(30,60,66,0.18);
}
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(.dc-step__body h3, .dc-timeline__body h4) { color: var(--dc-cream); }
.dc-site[data-mood="punk"] section.dc-sec:nth-of-type(2n):not(.dc-page-hero):not(.dc-final):not([class*="dc-punk-"]) :is(.dc-step__body p, .dc-timeline__body p) { color: rgba(250,243,219,0.72); }

/* ── SECTION HEADER kill blobs/sym overlays on punk pages ──────── */
.dc-site[data-mood="punk"] section > img.dc-blob,
.dc-site[data-mood="punk"] section > img[style*="opacity"] { display: none !important; }

/* ── FOOTER (already styled on home) keep parity ───────────────── */
.dc-site[data-mood="punk"] .dc-footer { background: #0E1F23 !important; border-top: 2px solid var(--punk-lead); }

/* ── HEADER text on dark heroes ────────────────────────────────── */
.dc-site[data-mood="punk"][data-page="governos"] .dc-header,
.dc-site[data-mood="punk"][data-page="empresas"] .dc-header,
.dc-site[data-mood="punk"][data-page="metodologia"] .dc-header { background: rgba(20,40,45,0.40) !important; }


/* ── LANGUAGE TOGGLE (PUNK MOOD) ─────────────────────────────────── */
.dc-site[data-mood="punk"] .dc-langtoggle {
  border-color: rgba(250,243,219,0.3);
  color: rgba(250,243,219,0.7);
}
.dc-site[data-mood="punk"] .dc-langtoggle:hover {
  background: rgba(250,243,219,0.1);
  color: var(--dc-cream);
  border-color: rgba(250,243,219,0.5);
}
.dc-site[data-mood="punk"] .dc-langtoggle span.is-active {
  color: var(--dc-cream);
  opacity: 1;
}
.dc-site[data-mood="punk"] .dc-langtoggle .dc-langtoggle-slash {
  opacity: 0.4;
}

/* ── Mobile font scaling (excludes plataforma + dashboards) ─── */
@media (max-width: 768px) {
  .dc-page-hero h1 { font-size: 32px !important; }
  .dc-page-hero .dc-lead { font-size: 15px !important; }
  .dc-h2 { font-size: 22px !important; }
  .dc-lead { font-size: 14.5px !important; }
  .dc-eyebrow { font-size: 10px !important; }
  .dc-sec h2 { font-size: 22px !important; }
  .dc-sec h3 { font-size: 17px !important; }
  .dc-sec p, .dc-sec li { font-size: 14px !important; }
  .dc-page { font-size: 15px; }
}
