/* Green Line / Green System — фирменная светлая тема
   «С нами не завянет!» — свежий, аграрный, надёжный, дружелюбный. */
:root{
  /* Бренд */
  --green:#5BA82E;            /* основной зелёный */
  --green-from:#4E9A2F;       /* градиент CTA/акценты */
  --green-to:#84C13D;
  --green-dark:#2E6B1A;       /* тёмно-зелёный: заголовки/акцент */
  --orange:#F39200;           /* оранжевый CTA */
  --orange-dark:#D87E00;
  --yellow:#FBBF24;           /* вторичное действие */
  --success:#5BA82E;          /* продажи/успех */
  --danger:#E2574C;           /* расход/предупреждение (приглушённый) */
  --danger-dark:#C8463C;

  /* Поверхности и текст */
  --bg:#F5F7F2;               /* тёплый светлый фон */
  --card:#FFFFFF;             /* карточки */
  --line:#E3E8DE;             /* границы */
  --text:#1E2A18;             /* основной текст */
  --muted:#6B7766;            /* приглушённый текст */

  /* Тинты для пиллов/флэшей */
  --green-tint:#EAF4E1;
  --orange-tint:#FCEFD9;
  --danger-tint:#FBE6E4;

  --radius:14px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(30,42,24,.04), 0 4px 14px rgba(46,107,26,.06);
  --shadow-hover:0 6px 22px rgba(46,107,26,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  display:flex;min-height:100vh;font-size:15px;line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--green-dark);text-decoration:none}
a:hover{color:var(--green)}

/* ---------- Sidebar ---------- */
.sidebar{
  width:236px;background:var(--card);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:20px 14px;position:fixed;top:0;bottom:0;left:0;
  box-shadow:1px 0 0 rgba(46,107,26,.02);
}
.brand{
  font-size:21px;font-weight:800;letter-spacing:-.01em;
  padding:4px 8px 2px;color:var(--green-dark);
}
.brand-tag{
  padding:0 8px 16px;margin-bottom:6px;border-bottom:1px solid var(--line);
  font-size:12px;font-weight:600;color:var(--orange);font-style:italic;
}
nav{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.nav-link{
  display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:var(--radius-sm);
  color:var(--text);transition:background .15s,color .15s;font-weight:600;font-size:14.5px;
}
.nav-link:hover{background:var(--green-tint);color:var(--green-dark)}
.nav-link.active{
  background:linear-gradient(135deg,var(--green),var(--green-from));
  color:#fff;box-shadow:0 3px 10px rgba(91,168,46,.32);
}
.nav-link.active:hover{color:#fff}
.nav-icon{width:22px;text-align:center;font-size:16px}
.src{
  margin-top:auto;font-size:12px;color:var(--muted);
  padding:12px 8px 2px;border-top:1px solid var(--line);
}
.src-file{color:var(--text);margin-top:4px;word-break:break-word;font-weight:600}
.src-date{margin-top:2px}

/* ---------- Content ---------- */
.content{margin-left:236px;flex:1;padding:26px 32px;width:calc(100% - 236px)}
.topbar{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.topbar h1{font-size:28px;font-weight:800;letter-spacing:-.02em;color:var(--green-dark)}
.burger{
  display:none;font-size:24px;cursor:pointer;color:var(--green-dark);
  line-height:1;padding:2px 6px;border-radius:8px;
}
.burger:hover{background:var(--green-tint)}
.nav-toggle{display:none}

/* ---------- Cards & grid ---------- */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin-bottom:20px;box-shadow:var(--shadow);
}
.card h2{font-size:17px;margin-bottom:16px;color:var(--green-dark);font-weight:700}
.empty{color:var(--muted)}
.grid{display:grid;gap:18px}
.grid.kpi{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
.grid.two{grid-template-columns:1fr 1fr}

/* ---------- KPI ---------- */
.kpi-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:box-shadow .18s,transform .18s;
}
.kpi-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green)}
.kpi-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.kpi-label{color:var(--muted);font-size:12.5px;margin-bottom:9px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.kpi-value{font-size:30px;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.kpi-value.hot{color:var(--danger)}
.kpi-value.green{color:var(--success)}
.kpi-sub{color:var(--muted);font-size:13px;margin-top:7px;font-weight:500}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:11px 13px;text-align:left;border-bottom:1px solid var(--line)}
th{
  color:var(--muted);font-weight:700;font-size:11.5px;text-transform:uppercase;
  letter-spacing:.04em;background:var(--green-tint);
}
th:first-child{border-top-left-radius:var(--radius-sm)}
th:last-child{border-top-right-radius:var(--radius-sm)}
tbody tr:nth-child(even){background:#FAFBF8}
tbody tr:hover{background:var(--green-tint)}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.rank{color:var(--green);font-weight:800;width:30px}
.pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700}
.pill.sale{background:var(--green-tint);color:var(--green-dark)}
.pill.buy{background:var(--danger-tint);color:var(--danger-dark)}
.pill.cat{background:var(--orange-tint);color:var(--orange-dark)}

/* Остатки на складе */
.stock{display:inline-block;padding:3px 11px;border-radius:20px;font-size:12.5px;font-weight:700;white-space:nowrap}
.stock.ok{background:var(--green-tint);color:var(--green-dark)}
.stock.low{background:#FDF3D6;color:#9A6B00}
.stock.out{background:var(--danger-tint);color:var(--danger-dark)}

/* Статусы клиента */
.pill.active{background:var(--green-tint);color:var(--green-dark)}
.pill.vip{background:var(--orange-tint);color:var(--orange-dark)}
.pill.lead{background:#E3EEFB;color:#1D4ED8}
.pill.inactive{background:#ECEFEA;color:#6B7766}
.pill.lost{background:var(--danger-tint);color:var(--danger-dark)}

/* Этапы воронки */
.pill.funnel-lead{background:#E3EEFB;color:#1D4ED8}
.pill.funnel-contact{background:#DCF3F1;color:#0E7C7B}
.pill.funnel-negotiation{background:#FDF3D6;color:#9A6B00}
.pill.funnel-deal{background:var(--orange-tint);color:var(--orange-dark)}
.pill.funnel-client{background:var(--green-tint);color:var(--green-dark)}
.pill.funnel-lost{background:#ECEFEA;color:#6B7766}

/* RFM-сегменты */
.pill.seg-vip{background:var(--orange-tint);color:var(--orange-dark)}
.pill.seg-loyal{background:var(--green-tint);color:var(--green-dark)}
.pill.seg-new{background:#E3EEFB;color:#1D4ED8}
.pill.seg-leaving{background:#FDF3D6;color:#9A6B00}
.pill.seg-lost{background:var(--danger-tint);color:var(--danger-dark)}

/* Карточка клиента */
.client-header{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.client-header .pill{font-size:13px}
.client-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.client-info-grid .row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px dashed var(--line)}
.client-info-grid .row .k{color:var(--muted);font-weight:600}
.client-info-grid .row .v{text-align:right;font-weight:600}
.client-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}

/* Воронка — горизонтальные полосы */
.funnel-visual{display:flex;flex-direction:column;gap:10px}
.funnel-bar{display:flex;align-items:center;gap:14px}
.funnel-bar .track{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:10px;overflow:hidden;min-width:120px}
.funnel-bar .fill{padding:12px 14px;border-radius:10px 0 0 10px;color:#fff;font-weight:700;white-space:nowrap;
  background:linear-gradient(135deg,var(--green),var(--green-from));min-width:46px}
.funnel-bar .label{width:120px;font-weight:700;color:var(--green-dark)}
.funnel-bar .amount{width:150px;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}

@media(max-width:860px){
  .client-info-grid{grid-template-columns:1fr}
  .funnel-bar .amount{display:none}
}

/* ---------- Forms ---------- */
form.filters{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;color:var(--muted);font-weight:600}
input,select,textarea{
  background:var(--card);border:1px solid var(--line);color:var(--text);
  padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(91,168,46,.15);
}
input[type=file]{padding:8px 12px}

.btn{
  background:var(--orange);color:#fff;border:none;padding:11px 20px;border-radius:var(--radius-sm);
  font-weight:700;cursor:pointer;font-size:14px;font-family:inherit;
  transition:background .15s,box-shadow .15s,transform .05s;box-shadow:0 2px 8px rgba(243,146,0,.25);
}
.btn:hover{background:var(--orange-dark);box-shadow:0 4px 14px rgba(243,146,0,.32)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:var(--green);box-shadow:0 2px 8px rgba(91,168,46,.25)}
.btn.ghost:hover{background:var(--green-from)}

.chart-wrap{position:relative;height:300px}
.muted{color:var(--muted)}
.note{font-size:12.5px;color:var(--muted);margin-top:10px;line-height:1.5}
.answer{white-space:pre-wrap;line-height:1.6}

.flash{
  background:var(--green-tint);border:1px solid var(--green);color:var(--green-dark);
  padding:13px 16px;border-radius:var(--radius-sm);margin-bottom:18px;font-weight:600;
}
.flash.err{background:var(--danger-tint);border-color:var(--danger);color:var(--danger-dark)}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .grid.two{grid-template-columns:1fr}
  .sidebar{transform:translateX(-100%);transition:transform .2s;z-index:20;box-shadow:var(--shadow-hover)}
  .nav-toggle:checked ~ .sidebar{transform:translateX(0)}
  .content{margin-left:0;width:100%;padding:18px}
  .burger{display:block}
  .topbar h1{font-size:23px}
}
