/* Калькулятор-диагностика чистой прибыли — светлая тема под лендинги Никадемии. Mobile-first. */
:root {
  --bg: #FFFFFF; --bg-alt: #F8FAFC; --fg: #0F172A; --fg-muted: #475569; --fg-soft: #64748B;
  --cta: #1E40AF; --cta-hover: #1E3A8A; --accent: #FB923C; --accent-soft: #FFF4EB;
  --divider: #E5E7EB; --border: #E2E8F0;
  --red: #EF4444; --warn: #F59E0B; --green: #22C55E; --leader: #0EA5E9;
  --radius-card: 14px; --radius-btn: 10px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg-alt); color: var(--fg);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
  font-size: 16px; line-height: 1.5; -webkit-text-size-adjust: 100%; }
.wrap { max-width: 600px; margin: 0 auto; padding: 18px 16px 56px; }

.head h1 { font-size: 23px; line-height: 1.25; margin: 4px 0 8px; letter-spacing: -.01em; }
.head .sub { color: var(--fg-muted); font-size: 14.5px; margin: 0 0 18px; }

.section-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  color: var(--cta); margin: 20px 0 8px; }
.section-title .sub-label { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--fg-soft); }

.field, .bucket { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-card);
  padding: 12px 14px; margin-bottom: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.field label { display: block; font-size: 14px; color: var(--fg); margin-bottom: 6px; font-weight: 500; }
.sub-label { display: block; color: var(--fg-soft); font-size: 12px; font-weight: 400; margin-top: 2px; }
.input-row { display: flex; align-items: center; gap: 8px; }
.calc-input { flex: 1; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-btn);
  color: var(--fg); font-size: 17px; padding: 11px 12px; outline: none; width: 100%;
  -moz-appearance: textfield; transition: border-color .12s; }
.calc-input:focus { border-color: var(--cta); }
.calc-input.ro { background: var(--bg-alt); color: var(--fg-muted); }
.calc-input.rec { color: var(--fg-soft); } /* норма-рекомендация серым, пока не правили */
.calc-input.rec:focus { color: var(--fg); }
.calc-input::-webkit-outer-spin-button, .calc-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.unit { color: var(--fg-soft); font-size: 15px; min-width: 16px; text-align: center; }

.mode-toggle { display: inline-flex; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-btn); overflow: hidden; margin: 4px 0 10px; }
.mode-toggle button { background: transparent; color: var(--fg-muted); border: none;
  padding: 8px 16px; font-size: 14px; cursor: pointer; }
.mode-toggle button.active { background: var(--cta); color: #fff; }

/* бакет */
.exp-row-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; margin-bottom: 6px; }
.exp-label { font-size: 15px; font-weight: 600; color: var(--fg); }
.exp-norm { font-size: 12px; color: var(--fg-soft); white-space: nowrap; background: var(--bg-alt);
  border: 1px solid var(--border); border-radius: 20px; padding: 2px 9px; }
.exp-comp { font-size: 12px; color: var(--cta); margin-top: 5px; min-height: 14px; font-weight: 500; }
.bucket-hint { font-size: 12px; color: var(--fg-soft); margin-top: 7px; }

.drill { margin-top: 10px; border-top: 1px solid var(--divider); padding-top: 4px; }
.drill > summary { cursor: pointer; font-size: 13px; color: var(--cta); padding: 7px 0; font-weight: 600; list-style: none; }
.drill > summary::-webkit-details-marker { display: none; }
.drill > summary::before { content: '＋ '; color: var(--accent); font-weight: 700; }
.drill[open] > summary::before { content: '－ '; }
.line-row { padding: 8px 0; border-top: 1px solid var(--divider); }
.line-name { font-size: 13.5px; color: var(--fg); }
.tag-fix { font-size: 10px; font-weight: 700; color: var(--accent); background: var(--accent-soft);
  border-radius: 4px; padding: 1px 5px; margin-left: 6px; text-transform: uppercase; letter-spacing: .03em; }
.line-note { font-size: 11.5px; color: var(--fg-soft); margin-top: 4px; }

.extras { background: var(--bg); border: 1px dashed var(--border); border-radius: var(--radius-card); padding: 4px 14px; margin-bottom: 10px; }
.extras > summary { cursor: pointer; padding: 12px 0; font-size: 14px; color: var(--cta); font-weight: 600; }
.extras-hint { font-size: 12px; color: var(--fg-soft); margin: 0 0 8px; }

.row-btns { display: flex; flex-direction: column; align-items: center; gap: 10px; margin-top: 12px; }
.calc-btn, .cta-btn { width: 100%; background: var(--cta); color: #fff; border: none;
  border-radius: var(--radius-btn); padding: 15px; font-size: 17px; font-weight: 600; cursor: pointer;
  box-shadow: 0 2px 8px rgba(30,64,175,.18); transition: background .15s, transform .05s; }
.calc-btn:active, .cta-btn:active { background: var(--cta-hover); transform: translateY(1px); }
.cta-btn:disabled { opacity: .6; }
.link-btn { background: none; border: none; color: var(--fg-soft); font-size: 13px; text-decoration: underline; cursor: pointer; padding: 4px; }

/* результат */
.result { display: none; margin-top: 22px; }
.result.show { display: block; animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.result-head { border-radius: var(--radius-card); padding: 18px; background: var(--bg);
  border: 1px solid var(--border); border-left: 5px solid var(--fg-soft); box-shadow: 0 2px 10px rgba(15,23,42,.06); }
.result-head.tone-green { border-left-color: var(--green); }
.result-head.tone-leader { border-left-color: var(--leader); }
.result-head.tone-warn { border-left-color: var(--warn); }
.result-head.tone-red { border-left-color: var(--red); }
.result-label { color: var(--fg-soft); font-size: 13px; font-weight: 500; }
.result-big { font-size: 28px; font-weight: 800; margin: 4px 0; letter-spacing: -.02em; }
.result-pct { font-size: 16px; font-weight: 500; color: var(--fg-muted); }
.result-rub.neg { color: var(--red); }
.zone-tag { display: inline-block; font-size: 13px; font-weight: 700; padding: 4px 12px; border-radius: 20px; margin: 8px 0 6px; color: #fff; }
.zone-tag.tone-green { background: var(--green); } .zone-tag.tone-leader { background: var(--leader); }
.zone-tag.tone-warn { background: var(--warn); } .zone-tag.tone-red { background: var(--red); }
.zone-note { color: var(--fg-muted); font-size: 13px; }

.ideal-prompt { background: var(--accent-soft); border: 1px solid #FCD9B6; border-radius: var(--radius-card); padding: 13px 15px; margin: 14px 0; }
.ideal-prompt p { margin: 0; font-size: 14px; color: #7C3A06; }

.summary { font-size: 15px; font-weight: 500; margin: 16px 2px 10px; }
.leaks { display: flex; flex-direction: column; gap: 10px; }
.leak-card { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-card);
  padding: 12px 14px; border-left: 4px solid var(--warn); box-shadow: 0 1px 3px rgba(15,23,42,.05); }
.leak-card.status-red { border-left-color: var(--red); }
.leak-card.status-yellow, .leak-card.status-yellow-low { border-left-color: var(--warn); }
.leak-title { display: flex; align-items: baseline; gap: 8px; }
.leak-num { color: var(--accent); font-size: 13px; font-weight: 800; }
.leak-name { font-size: 16px; font-weight: 700; }
.leak-stat { font-size: 14px; color: var(--fg); margin: 5px 0; }
.leak-lever { font-size: 13px; color: var(--fg-muted); }
.soft-note { font-size: 13px; color: var(--fg-muted); margin: 12px 2px; }

.extras-result { margin-top: 16px; background: var(--bg); border: 1px solid var(--border);
  border-left: 4px solid var(--cta); border-radius: var(--radius-card); padding: 15px; }
.extras-title { font-size: 13px; color: var(--fg-soft); font-weight: 500; }
.extras-big { font-size: 23px; font-weight: 800; margin: 4px 0 6px; }

.breakdown, .info-block { margin: 14px 0; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-card); padding: 4px 15px; }
.breakdown > summary, .info-block > summary { cursor: pointer; padding: 12px 0; font-size: 14px; color: var(--cta); font-weight: 600; }
.cat-table { display: flex; flex-direction: column; gap: 6px; padding-bottom: 10px; }
.cat-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: baseline;
  font-size: 14px; padding: 7px 0; border-bottom: 1px solid var(--divider); }
.cat-fact { font-weight: 700; } .cat-norm { color: var(--fg-soft); font-size: 12px; }
.cat-row.status-green .cat-fact { color: var(--green); }
.cat-row.status-yellow .cat-fact, .cat-row.status-yellow-low .cat-fact { color: var(--warn); }
.cat-row.status-red .cat-fact { color: var(--red); }
.info-explainer { font-size: 14px; color: var(--fg); margin: 2px 0 10px; }
.info-list { display: flex; flex-direction: column; gap: 8px; padding-bottom: 10px; }
.info-item { display: flex; flex-direction: column; gap: 2px; padding: 9px 11px; background: var(--bg-alt); border-radius: 8px; }
.info-item-name { font-size: 13px; font-weight: 700; color: var(--fg); }
.info-item-note { font-size: 12px; color: var(--fg-muted); }
.src-note { font-size: 11px; color: var(--fg-soft); margin: 8px 0 4px; }

.bridge { margin-top: 18px; background: linear-gradient(180deg, #fff 0%, var(--accent-soft) 100%);
  border: 1px solid #FCD9B6; border-radius: var(--radius-card); padding: 16px; }
.bridge-text { font-size: 15px; font-weight: 500; margin: 0 0 12px; }
.cta-reassure { font-size: 12px; color: var(--fg-muted); margin: 9px 0 0; text-align: center; }
.bridge.thanks { text-align: center; padding: 22px 16px; }
.thanks-title { font-size: 20px; font-weight: 800; color: var(--green); margin-bottom: 6px; }
.thanks-text { font-size: 14px; color: var(--fg-muted); margin: 0; }
.capture { margin-top: 12px; }
.capture-label { display: block; font-size: 13px; color: var(--fg-muted); margin-bottom: 6px; }
.contact-input.invalid { border-color: var(--red); }

.hint-error { color: var(--red); font-size: 14px; font-weight: 500; }
.foot { color: var(--fg-soft); font-size: 12px; margin-top: 26px; text-align: center; }
