/* ============================================================
   JYNX — /protheus/reforma-tributaria campaign styles
   ============================================================ */

/* ---------- hero ---------- */
.rthero { position: relative; overflow: hidden; padding-block: clamp(48px, 7vw, 90px); }
.rthero__atmo {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(55% 60% at 82% 10%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 70%),
    radial-gradient(45% 55% at 6% 0%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 65%);
}
.rthero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: .5; pointer-events: none;
  background-image: radial-gradient(color-mix(in srgb, var(--ink) 9%, transparent) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(70% 70% at 50% 25%, #000, transparent 75%);
          mask-image: radial-gradient(70% 70% at 50% 25%, #000, transparent 75%);
}
.rthero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.rthero__pill { display: inline-flex; align-items: center; gap: 7px; font-size: .8rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: #fff; background: var(--accent); padding: 6px 16px; border-radius: 100px; white-space: nowrap; }
.rthero h1 { font-size: clamp(2.4rem, 5.4vw, 4.2rem); letter-spacing: -0.035em; margin-top: 20px; }
.rthero__lead { margin-top: 22px; font-size: 1.2rem; line-height: 1.55; color: var(--ink-64); max-width: 48ch; }
.rthero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.rthero__trust { display: flex; align-items: center; gap: 14px; margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--hair); font-size: .98rem; color: var(--ink-64); flex-wrap: wrap; }
.rthero__trust b { color: var(--ink); font-weight: 800; }
.rthero__dot { width: 4px; height: 4px; border-radius: 50%; background: var(--accent); }

/* checklist card */
.rthero__visual { position: relative; }
.rtcard { background: var(--bg); border: 1px solid var(--hair); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); padding: 24px; }
.rtcard__head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 16px; border-bottom: 1px solid var(--hair); }
.rtcard__tag { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: .98rem; }
.rtcard__erp { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 6px; background: var(--bg-alt); color: var(--ink-64); border: 1px solid var(--hair); }
.rtcard__list { list-style: none; margin: 0; padding: 16px 0; display: flex; flex-direction: column; gap: 12px; border-bottom: 1px solid var(--hair); }
.rtcard__list li { display: flex; align-items: center; gap: 11px; flex-wrap: nowrap; }
.rtcard__ic { color: var(--accent); display: inline-flex; flex-shrink: 0; }
.rtcard__lbl { flex: 1; min-width: 0; font-weight: 600; font-size: .98rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rtcard__st { flex-shrink: 0; font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 100px; white-space: nowrap; }
.rtcard__st--ajustar { color: var(--accent); background: var(--accent-12); }
.rtcard__st--rever { color: #B07A00; background: color-mix(in srgb, #E8A100 16%, var(--bg)); }
.rtcard__st--ok { color: #1F8A5B; background: color-mix(in srgb, #1F8A5B 13%, var(--bg)); }
.rtcard__foot { display: flex; align-items: center; gap: 9px; padding-top: 16px; font-size: .9rem; color: var(--ink-48); }
.rtcard__foot svg { color: #1F8A5B; flex-shrink: 0; }
@media (max-width: 980px) {
  .rthero__inner { grid-template-columns: 1fr; }
  .rthero__visual { max-width: 460px; margin-top: 8px; }
  .rthero__lead { max-width: none; }
}

/* ---------- riscos ---------- */
.rtriscos__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 52px; }
.rtriscos__card { padding: 26px; }
.rtriscos__card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: color-mix(in srgb, var(--accent) 30%, var(--hair)); }
.rtriscos__ic { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 13px; background: var(--accent-12); color: var(--accent); margin-bottom: 18px; transition: transform .25s; }
.rtriscos__card:hover .rtriscos__ic { transform: scale(1.08) rotate(-4deg); }
.rtriscos__card h3 { font-size: 1.2rem; }
.rtriscos__card p { margin-top: 9px; color: var(--ink-64); }
@media (max-width: 860px) { .rtriscos__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .rtriscos__grid { grid-template-columns: 1fr; } }

/* ---------- como ---------- */
.rtcomo__steps { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 56px; }
.rtcomo__line { position: absolute; top: 28px; left: 14%; right: 14%; height: 2px; background: repeating-linear-gradient(90deg, var(--hair) 0 7px, transparent 7px 14px); z-index: 0; }
.rtcomo__step { position: relative; z-index: 1; }
.rtcomo__node { position: relative; width: 58px; height: 58px; border-radius: 16px; background: var(--bg); border: 1px solid var(--hair); display: grid; place-items: center; color: var(--accent); box-shadow: var(--shadow-sm); transition: transform .25s, box-shadow .25s; }
.rtcomo__step:hover .rtcomo__node { transform: translateY(-4px); box-shadow: var(--shadow); }
.rtcomo__num { position: absolute; top: -8px; right: -8px; width: 25px; height: 25px; border-radius: 50%; background: var(--accent); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: .82rem; display: grid; place-items: center; }
.rtcomo__step h3 { font-size: 1.28rem; margin-top: 22px; }
.rtcomo__step p { margin-top: 10px; color: var(--ink-64); }
.rtcomo__cta { margin-top: 48px; }
@media (max-width: 760px) { .rtcomo__steps { grid-template-columns: 1fr; gap: 30px; } .rtcomo__line { display: none; } }

/* ---------- prova ---------- */
.rtprova__trust { text-align: center; max-width: 760px; margin: 0 auto 44px; font-size: 1.22rem; line-height: 1.5; color: var(--ink-64); }
.rtprova__trust b { color: var(--ink); font-weight: 800; }

/* ---------- cross-sell ---------- */
.rtcross__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 48px; }
.rtcross__card { padding: 22px; display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: center; text-decoration: none; }
.rtcross__card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: color-mix(in srgb, var(--accent) 30%, var(--hair)); }
.rtcross__ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--ink); color: var(--bg); flex-shrink: 0; }
.rtcross__card h3 { font-size: 1.12rem; }
.rtcross__card p { font-size: .92rem; color: var(--ink-64); margin-top: 3px; line-height: 1.4; }
.rtcross__arrow { color: var(--ink-28); transition: color .2s, transform .2s; }
.rtcross__card:hover .rtcross__arrow { color: var(--accent); transform: translate(2px, -2px); }
@media (max-width: 900px) { .rtcross__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .rtcross__grid { grid-template-columns: 1fr; } }

/* ---------- cta ---------- */
.rtcta { position: relative; overflow: hidden; text-align: center; }
.rtcta__mark { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 0; pointer-events: none; }
.rtcta__inner { position: relative; z-index: 1; max-width: 760px; }
.rtcta__inner .rthero__pill { margin-bottom: 22px; }
.rtcta h2 { color: var(--bg); font-size: clamp(2rem, 4.5vw, 3.3rem); }
.rtcta p { margin: 20px auto 0; color: color-mix(in srgb, white 74%, var(--ink)); font-size: 1.18rem; max-width: 50ch; }
.rtcta__btns { display: flex; gap: 14px; justify-content: center; margin-top: 36px; flex-wrap: wrap; }
