:root {
  --bg: #e9eef5;
  --card: #fff;
  --text: #1f2a44;
  --muted: #6c7a99;
  --blue: #3f6be8;
  --accent: #4cb5ff;
  --ring: rgba(63, 107, 232, 0.15);
  --ok: #2fbf71;
  --warn: #ffb100;
  --bad: #f05454;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font: 14px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}

/* каркас/вкладки/карточки — как у тебя */
.topbar{position:sticky;top:0;z-index:10;backdrop-filter:saturate(1.2) blur(6px);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;background:rgba(255,255,255,.88);border-bottom:1px solid #dfe5f0}
.brand{display:flex;gap:12px;align-items:center;min-width:0}
.logo{width:36px;height:36px;border-radius:10px;background:var(--blue);box-shadow:0 4px 16px var(--ring)}
.title{font-weight:700;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subtitle{color:var(--muted);font-size:12px;margin-top:-2px}
.daterange{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.daterange input[type="date"]{padding:6px 8px;border:1px solid #ccd6ea;border-radius:8px;background:#fff}
.dash{opacity:.6}
.chk{display:flex;gap:6px;align-items:center;color:var(--muted)}
.btn{padding:8px 12px;border:0;border-radius:10px;cursor:pointer}
.btn.primary{background:var(--blue);color:#fff}

.tabs{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid #dde4f3;background:#f7f9fd;position:sticky;top:64px;z-index:9}
.tab{padding:8px 12px;border-radius:8px;background:#fff;border:1px solid #e2e8f8;cursor:pointer}
.tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}

main{padding:16px;max-width:1400px;margin:0 auto}
.tabpage{display:none}
.tabpage.active{display:block}

.cards{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}
@media (max-width:1200px){.cards{grid-template-columns:repeat(3,1fr)}}
@media (max-width:920px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cards{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid #e3e8f5;border-radius:12px;padding:14px;box-shadow:0 4px 14px var(--ring)}
.card.big{grid-column:span 2}
.card-title{font-weight:600;margin-bottom:8px}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.kpi .kpi-title{color:var(--muted);font-size:12px}
.kpi .kpi-value{font-size:22px;font-weight:700;margin-top:4px}

.grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px;margin-bottom:16px}
@media (max-width:1200px){.grid{grid-template-columns:1fr}}

.segmented{display:flex;gap:6px}
.seg{padding:6px 10px;border:1px solid #ccd6ea;border-radius:999px;background:#fff;cursor:pointer}
.seg.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.legend{margin-top:8px;color:var(--muted);font-size:12px}
.filters{display:flex;gap:14px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.muted{color:var(--muted);font-size:12px}

/* таблицы */
.table-wrap{overflow:auto;border:1px solid #e5ebf8;border-radius:10px;background:#fff}
.table-wrap.wide{max-height:70vh;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse}
th,td{padding:10px 12px;border-bottom:1px solid #eef3fb;white-space:nowrap}
thead th{position:sticky;top:0;background:#f8fbff;border-bottom:1px solid #e0e8f8;z-index:3}

/* RNP — стили, которые у тебя уже были в текущей версии */
#rnpTableWrap{ -webkit-overflow-scrolling:touch; touch-action: pan-x pan-y; overscroll-behavior:none }
.matrix th:first-child,.matrix td:first-child{min-width:140px;max-width:180px}
.matrix tbody tr:nth-child(odd) td{background:#fcfdff}
.matrix td.right,.matrix th.right{text-align:right}
.matrix tbody tr.row-active td{background:#eef4ff !important}
.matrix tbody tr.total-row td{background:#f8fbff;font-weight:600}
#rnpTableWrap,#rnpTableWrap *{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}
.mobile-date-bar{display:none;align-items:center;gap:8px;margin:8px 0 12px 0}
.iconbtn{border:1px solid #d5def3;background:#fff;border-radius:10px;padding:6px 10px;cursor:pointer;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}
.dates-scroll{flex:1;display:flex;gap:6px;overflow:auto;padding:4px;border:1px solid #e5ebf8;border-radius:999px;background:#fff;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.date-pill{flex:0 0 auto;padding:6px 10px;border:1px solid #e2e8f8;border-radius:999px;background:#f7f9ff;scroll-snap-align:center;cursor:pointer;font-size:12px;min-height:32px;display:flex;align-items:center}
.date-pill.active{background:var(--blue);color:#fff;border-color:var(--blue)}

@media (max-width:1024px){.tabs{top:58px}}
@media (max-width:900px){
  .card.big{grid-column:span 1}
  .mobile-date-bar{display:flex}
  .topbar{flex-direction:column;gap:12px;padding:12px 16px}
  .brand{width:100%;justify-content:center}
  .daterange{width:100%;justify-content:center;flex-wrap:wrap;gap:8px}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{flex:0 0 auto;white-space:nowrap}
}
@media (max-width:640px){
  body{font-size:13px}
  th,td{padding:8px 10px}
  .subtitle{display:none}
  main{padding:12px}
  .cards{gap:8px;margin-bottom:12px}
  .card{padding:12px}
  .table-wrap{font-size:12px}
  .table-wrap.wide{max-height:60vh}
  .matrix th:first-child,.matrix td:first-child{min-width:120px;max-width:160px}
}
@media (max-width:480px){
  body{font-size:12px}
  .logo{width:32px;height:32px}
  .title{font-size:14px}
  .btn{padding:8px 10px}
  .matrix th:first-child,.matrix td:first-child{min-width:110px;max-width:140px}
}
.footer{padding:16px;color:var(--muted);text-align:center}
