/* CalculVenituri.ro — stiluri principale (tokens definite în critical CSS din base.html) */

.intro { color: var(--muted); font-size: 1.02rem; max-width: 70ch; margin-top: 0; }

/* ───────── Calculator ───────── */
.calc {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin: 18px 0 8px;
}
@media (max-width: 720px) { .calc { grid-template-columns: 1fr; } }

.calc-form, .calc-rezultat {
  background: var(--card); border: 1px solid var(--linie);
  border-radius: var(--radius); padding: 18px;
}
.calc-form { box-shadow: 0 1px 3px rgba(11, 61, 107, .06); }

.mod { display: flex; gap: 8px; margin-bottom: 14px; }
.mod-opt {
  flex: 1; text-align: center; padding: 9px 6px; border: 1px solid var(--linie);
  border-radius: 10px; cursor: pointer; font-size: .92rem; font-weight: 600; color: var(--muted);
  background: #f8fafc; user-select: none;
}
.mod-opt:has(input:checked) { background: var(--azur); color: #fff; border-color: var(--azur); }
.mod-opt:has(input:focus-visible) { outline: 3px solid var(--azur2); outline-offset: 2px; }
.mod-opt input { position: absolute; opacity: 0; width: 1px; height: 1px; }

.camp { display: block; margin-bottom: 12px; }
.camp > span { display: block; font-size: .82rem; font-weight: 600; color: var(--muted); margin-bottom: 5px; }
.camp input[type=number], .camp select {
  width: 100%; padding: 12px; font-size: 1.05rem; border: 1px solid var(--linie);
  border-radius: 10px; background: #fff; color: var(--fg);
}
.camp input:focus, .camp select:focus { outline: 2px solid var(--azur2); border-color: var(--azur2); }
.camp-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.camp-mic > span { font-weight: 500; }

.optiuni { margin: 6px 0 14px; border-top: 1px dashed var(--linie); padding-top: 10px; }
.optiuni summary { cursor: pointer; font-weight: 600; color: var(--azur2); font-size: .9rem; }
.check { display: flex; align-items: flex-start; gap: 8px; margin: 10px 0; font-size: .9rem; }
.check input { margin-top: 3px; }

.btn {
  width: 100%; padding: 13px; font-size: 1.05rem; font-weight: 700; color: #fff;
  background: linear-gradient(180deg, var(--verde2), var(--verde)); border: 0; border-radius: 11px;
  cursor: pointer;
}
.btn:hover { filter: brightness(1.05); }

/* ───────── Rezultat ───────── */
.calc-rezultat { background: linear-gradient(180deg, #f4f9ff, #fff); }
.net-mare { text-align: center; padding: 8px 0 14px; border-bottom: 1px solid var(--linie); margin-bottom: 12px; }
.net-eticheta { display: block; font-size: .85rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.net-valoare { display: block; font-size: 2.4rem; line-height: 1.1; margin: 4px 0; }
.net-valoare b { color: var(--verde); }
.net-sub { display: block; font-size: .9rem; color: var(--muted); }

.defalcare { width: 100%; border-collapse: collapse; font-size: .94rem; }
.defalcare th { text-align: left; font-weight: 500; color: var(--muted); padding: 7px 0; }
.defalcare td { text-align: right; padding: 7px 0; font-variant-numeric: tabular-nums; }
.defalcare tr { border-bottom: 1px solid #eef2f7; }
.defalcare .r-total th, .defalcare .r-total td { font-weight: 800; color: var(--fg); font-size: 1.05rem; border-top: 2px solid var(--linie); }
.defalcare .r-ang th, .defalcare .r-ang td { color: #5b6b7f; font-size: .85rem; border-bottom: 0; }
.nota-mica { font-size: .8rem; color: #5b6b7f; margin: 10px 0 0; }
.camp-eroare { color: #b3261e; font-size: .82rem; margin-top: 6px; }
/* învinge `.camp > span { display:block }` ca atributul `hidden` să funcționeze (0,2,0 > 0,1,1) */
.camp-eroare[hidden] { display: none; }

/* ───────── Conținut ───────── */
.continut { max-width: 75ch; }
.continut h2 { font-size: 1.3rem; margin-top: 1.6em; letter-spacing: -.01em; }
.formula { background: #0f2942; color: #cfe6ff; padding: 14px 16px; border-radius: 10px; font-size: .9rem; overflow-x: auto; white-space: pre-wrap; }
.faq details { border: 1px solid var(--linie); border-radius: 10px; padding: 10px 14px; margin: 8px 0; background: #fff; }
.faq summary { cursor: pointer; font-weight: 600; }
.faq p { margin: 8px 0 2px; color: #415061; }

.sume-linkuri { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.sume-linkuri a {
  display: inline-block; padding: 7px 12px; background: #eef4fb; border: 1px solid #dbe7f3;
  border-radius: 999px; text-decoration: none; font-size: .9rem; color: var(--azur2);
}
.sume-linkuri a:hover { background: #e0edfa; }

/* Pagini de conținut/text */
.text-pag { max-width: 72ch; }
.text-pag h2 { font-size: 1.25rem; margin-top: 1.4em; }
.text-pag table { width: 100%; border-collapse: collapse; margin: 14px 0; font-size: .92rem; }
.text-pag th, .text-pag td { border: 1px solid var(--linie); padding: 8px 10px; text-align: left; }
.text-pag thead th { background: #f1f6fb; }

.eroare { text-align: center; padding: 50px 0; }
.eroare h1 { font-size: 3rem; color: var(--azur); }

.firimituri { font-size: .85rem; color: var(--muted); margin: 0 0 6px; }
.firimituri a { color: var(--azur2); text-decoration: none; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
