*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#059669;
  --primary-600:#047857;
  --primary-300:#34d399;
  --accent:#3b82f6;
  --text:#0f172a;
  --text-2:#475569;
  --muted:#94a3b8;
  --bg:#ffffff;
  --bg-2:#f8fafc;
  --bg-3:#f1f5f9;
  --border:#e2e8f0;
  --shadow-1:0 1px 2px rgba(0,0,0,.05);
  --shadow-2:0 4px 10px rgba(0,0,0,.08);
  --shadow-3:0 10px 24px rgba(0,0,0,.10);
  --radius-6:6px;
  --radius-10:10px;
  --radius-14:14px;
  --space-4:4px;
  --space-8:8px;
  --space-12:12px;
  --space-16:16px;
  --space-20:20px;
  --space-24:24px;
  --space-32:32px;
  --space-40:40px
}
html,body{height:100%}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(135deg,#fff 0%,#fafbfc 40%,#f5f7fb 100%);
  color:var(--text);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:14px
}
.app{max-width:1280px;margin:0 auto;padding:var(--space-20)}
.region{margin-block:var(--space-20)}
.header{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius-14);
  box-shadow:var(--shadow-1);
  padding:var(--space-20);
  position:relative
}
.header::before{
  content:"";
  position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:14px 14px 0 0
}
.header__title{
  text-align:center;
  font-weight:700;
  font-size:clamp(18px,2.6vw,24px);
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:var(--space-16)
}
.header__controls{
  display:flex;flex-wrap:wrap;gap:var(--space-12);
  align-items:center;justify-content:space-between
}
.controls__left{
  display:flex;flex-wrap:wrap;gap:var(--space-12);align-items:flex-end
}
.field{display:flex;flex-direction:column;gap:4px}
.field__label{
  font-size:11px;font-weight:600;color:var(--text-2);letter-spacing:.02em
}
.input{
  appearance:none;
  padding:8px 10px;
  min-width:150px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--bg);
  color:var(--text)
}
.input:focus{
  outline:0;border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(5,150,105,.08)
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:34px;padding:0 12px;
  border-radius:8px;border:1px solid transparent;
  font-weight:700;font-size:12px;letter-spacing:.03em;text-transform:uppercase;
  cursor:pointer
}
.btn--primary{background:var(--primary);color:#fff}
.btn--primary:hover{background:var(--primary-600);box-shadow:var(--shadow-2)}
.btn--ghost{background:transparent;border-color:var(--border);color:var(--text)}
.btn--ghost:hover{background:var(--bg-2)}
.status{
  display:flex;align-items:center;gap:6px;
  padding:8px 10px;background:var(--bg-2);
  border:1px solid var(--border);border-radius:10px
}
.status__dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}
.status__text{font-weight:600;color:var(--text-2);font-size:11px}
.status__time{color:var(--muted);font-size:11px}
.main{}
#statsContainer .stats-grid{
  display:grid;gap:var(--space-12);
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr))
}
.stat-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-14);box-shadow:var(--shadow-1);
  padding:var(--space-16)
}
.stat-value{font-size:clamp(22px,3.5vw,32px);font-weight:800;color:var(--primary)}
.stat-label{margin-top:4px;color:var(--text-2);font-weight:700;letter-spacing:.08em;font-size:11px;text-transform:uppercase}
#chartsContainer .charts-grid{
  display:grid;gap:var(--space-16);
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr))
}
@media (min-width:1024px){
  #chartsContainer .charts-grid{grid-template-columns:repeat(12,1fr)}
  #chartsContainer .chart-container{grid-column:span 6}
}
.chart-container{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-14);box-shadow:var(--shadow-1);
  padding:var(--space-16)
}
.chart-title{
  font-size:16px;font-weight:800;color:var(--text);
  padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid var(--border);
  display:flex;gap:8px;align-items:center
}
.data-table{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-14);box-shadow:var(--shadow-1);overflow:hidden
}
.table-title{
  font-size:16px;font-weight:800;color:var(--text);
  padding:10px 12px;border-left:4px solid var(--primary);background:var(--bg-2)
}
table{
  width:100%;
  border-collapse:collapse;
  font-size:13px
}
th,td{
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  line-height:1.2
}
th{
  background:var(--bg-2);
  font-weight:800;color:var(--text-2);
  text-transform:uppercase;font-size:11px;letter-spacing:.06em;position:sticky;top:0;z-index:1
}
tr:hover{background:#f6fffb}
tr:nth-child(even){background:rgba(248,250,252,.5)}
.loading{display:grid;place-items:center;padding:var(--space-16);color:var(--text-2);font-size:13px}
.error-message{
  background:#fff5f5;color:#b91c1c;border:1px solid #fee2e2;
  border-left:4px solid #ef4444;border-radius:10px;padding:12px 14px;font-size:13px
}
.no-data{
  text-align:center;color:var(--muted);font-style:italic;
  padding:12px;background:var(--bg-2);border:1px dashed var(--border);
  border-radius:10px;font-size:13px
}
.realtime-indicator{
  position:fixed;top:16px;right:16px;z-index:1000;
  background:var(--bg);border:2px solid var(--primary);color:var(--primary);
  padding:8px 10px;border-radius:999px;box-shadow:var(--shadow-2);font-weight:700;font-size:11px
}
.special-layout{
  display:grid;gap:var(--space-16)
}
@media (min-width:900px){
  .special-layout{grid-template-columns:1fr 1fr}
}
.modal{
  position:fixed;inset:0;display:none;z-index:9999
}
.modal--open{display:block}
.modal__backdrop{
  position:absolute;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(6px)
}
.modal__dialog{
  position:relative;margin:6vh auto 0;max-width:760px;width:calc(100% - 32px);
  background:var(--bg);border:1px solid var(--border);border-radius:14px;
  box-shadow:var(--shadow-3);display:flex;flex-direction:column;max-height:88vh
}
.modal__header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px;border-bottom:1px solid var(--border)
}
.modal__title{font-size:14px;font-weight:800;color:var(--text)}
.modal__close{
  border:1px solid var(--border);background:transparent;border-radius:8px;
  width:32px;height:32px;cursor:pointer;font-size:14px
}
.modal__content{padding:12px;overflow:auto}
.modal__footer{
  padding:10px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px
}
.chart-skeleton{display:grid;gap:8px}
.skeleton-title{height:16px;background:var(--bg-3);border-radius:6px}
.skeleton-content{height:140px;background:var(--bg-3);border-radius:8px}
@media (max-width:480px){
  .app{padding:var(--space-16)}
  .header__controls{gap:var(--space-8)}
  .controls__left{gap:var(--space-8)}
  .input{min-width:0;width:100%}
  .btn{width:100%}
}
:focus-visible{outline:3px solid rgba(5,150,105,.35);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
