/* ==========================================================================
   Ajudo — Calculadora PJ vs CLT (estilos específicos)
   Reusa skeleton / preview-label / rational do padrão (docs/PADROES-FERRAMENTAS.md).
   Específico: veredito, comparação em 2 colunas e box de ponto de equilíbrio.
   ========================================================================== */

/* Carimbo de vigência das tabelas (sinal YMYL) */
.table-stamp {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--green-deep);
  background: #e4ecdf;
  border: 1px solid var(--green);
  border-radius: 999px;
  padding: 5px 14px;
  margin-top: 12px;
}

.preview-label {
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  margin-bottom: 10px;
}

/* Painel de resultado */
.rescisao-result-wrap { position: sticky; top: calc(var(--header-h) + 16px); }

.rescisao-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  color: var(--ink-soft);
  background: var(--paper-deep);
  border: 1.5px dashed var(--line-strong);
  border-radius: var(--radius-lg);
  padding: clamp(32px, 5vw, 56px) 24px;
}
.rescisao-empty svg { width: 44px; height: 44px; opacity: 0.55; }
.rescisao-empty p { max-width: 30ch; font-size: 0.95rem; }

/* Loading skeleton (padrão §4.1) */
.rescisao-skeleton {
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: var(--card);
  border: 1.5px solid var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop), var(--shadow-md);
  padding: clamp(20px, 3vw, 28px);
  animation: skeletonFadeIn 0.18s ease;
}
.rescisao-skeleton[hidden] { display: none; }
.skel-block {
  background: linear-gradient(90deg, var(--paper-deep) 25%, var(--line) 50%, var(--paper-deep) 75%);
  background-size: 200% 100%;
  border-radius: var(--radius);
  animation: shimmer 1.2s infinite ease-in-out;
}
.skel-total  { height: 80px; }
.skel-row    { height: 18px; }
.skel-row.w75 { width: 75%; }
.skel-row.w50 { width: 50%; }
.skel-row.w60 { width: 60%; }
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@keyframes skeletonFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Card de resultado */
.rescisao-result {
  background: var(--card);
  border: 1.5px solid var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop), var(--shadow-md);
  padding: clamp(20px, 3vw, 28px);
}
.rescisao-result.is-entering { animation: resultReveal 0.3s ease; }
@keyframes resultReveal {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.result-rows { list-style: none; display: flex; flex-direction: column; }
.result-rows li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  font-size: 0.92rem;
  padding: 7px 2px;
  border-bottom: 1.5px dashed var(--line);
}
.result-rows li:last-child { border-bottom: none; }
.result-rows .row-label { color: var(--ink); }
.result-rows .row-value { font-weight: 700; white-space: nowrap; font-variant-numeric: tabular-nums; }
.result-rows .row-value.is-negative { color: var(--terracotta); }

.result-actions { margin-top: 20px; }

/* ---- Veredito ----------------------------------------------------------- */
.pjc-verdict {
  display: flex;
  flex-direction: column;
  gap: 3px;
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-bottom: 18px;
  color: var(--paper);
}
.pjc-verdict.is-pj  { background: var(--green-deep); }
.pjc-verdict.is-clt { background: var(--terracotta); }
.pjc-verdict strong { font-family: var(--font-display); font-size: clamp(1.3rem, 3.5vw, 1.7rem); line-height: 1.15; }
.pjc-verdict span { font-size: 0.86rem; color: rgba(248, 243, 232, 0.85); }
.pjc-verdict span strong { font-family: var(--font-body); font-size: 0.86rem; color: var(--mustard); }

/* ---- Comparação em duas colunas ----------------------------------------- */
.pjc-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.pjc-col {
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 14px 8px;
  background: var(--paper-deep);
}
.pjc-col-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.pjc-col-tag {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
}
.pjc-col-total { font-family: var(--font-display); font-size: 1.25rem; font-weight: 700; color: var(--green-deep); }
.pjc-col.is-clt .pjc-col-total { color: var(--ink); }

/* ---- Ponto de equilíbrio + aviso ---------------------------------------- */
.pjc-breakeven {
  margin-top: 16px;
  padding: 13px 16px;
  border-radius: var(--radius);
  background: #e4ecdf;
  border: 1.5px solid var(--green);
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--ink);
}
.pjc-aviso {
  margin-top: 12px;
  padding: 11px 14px;
  border-radius: var(--radius);
  background: var(--mustard-soft, #fbf1d6);
  border: 1.5px solid var(--mustard);
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--ink);
}

/* ---- Seção "Entenda os cálculos" (padrão §6) ---------------------------- */
.rescisao-rational {
  margin-top: 16px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.rescisao-rational[hidden] { display: none; }
.rescisao-rational > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 13px 18px;
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--ink);
  cursor: pointer;
  list-style: none;
  background: var(--paper-deep);
  user-select: none;
}
.rescisao-rational > summary::-webkit-details-marker { display: none; }
.rescisao-rational > summary .rational-icon { display: flex; align-items: center; gap: 7px; }
.rescisao-rational > summary .rational-icon svg { width: 16px; height: 16px; opacity: 0.7; flex-shrink: 0; }
.rational-chevron { width: 16px; height: 16px; color: var(--ink-soft); transition: transform 0.2s ease; flex-shrink: 0; }
.rescisao-rational[open] .rational-chevron { transform: rotate(180deg); }
.rational-body { padding: 0 18px 18px; background: var(--paper-deep); display: flex; flex-direction: column; }
.rational-item { border-top: 1.5px dashed var(--line); padding: 14px 0 2px; }
.rational-item:first-child { border-top: none; padding-top: 18px; }
.rational-item h4 { font-family: var(--font-body); font-size: 0.84rem; font-weight: 700; color: var(--ink); margin-bottom: 5px; }
.rational-item p { font-size: 0.84rem; color: var(--ink-soft); line-height: 1.55; margin-bottom: 6px; }
.rational-item p:last-child { margin-bottom: 10px; }
.rational-source {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--green-deep);
  background: #e4ecdf;
  border: 1px solid var(--green);
  border-radius: 999px;
  padding: 3px 10px;
  margin-top: 2px;
  text-decoration: none;
}

/* Tabelas de faixas (conteúdo SEO) */
.sl-table-wrap { overflow-x: auto; margin: 14px 0 22px; }
.sl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--card);
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
}
.sl-table th, .sl-table td { text-align: left; padding: 10px 14px; border-bottom: 1.5px solid var(--line); }
.sl-table th {
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  background: var(--paper-deep);
}
.sl-table tr:last-child td { border-bottom: none; }
.sl-table td:last-child, .sl-table th:last-child { text-align: right; font-variant-numeric: tabular-nums; }

/* Form mais estreito: campos são blocados/curtos, sobra mais espaço para a
   comparação à direita. Stylesheet carrega só nesta página → escopo seguro. */
@media (min-width: 861px) {
  .tool-app { grid-template-columns: minmax(0, 0.66fr) minmax(0, 1fr); }
}

@media (max-width: 860px) {
  .rescisao-result-wrap { position: static; }
}
@media (max-width: 420px) {
  .pjc-cols { grid-template-columns: 1fr; }
}
