/* ============================================================
   ATUM DASHBOARD - stil
   ============================================================ */
:root{
  --bg:#f6f7f9; --surface:#ffffff; --ink:#1c1d20; --muted:#6b6f76;
  --line:#e6e8ec; --line2:#d2d6dc; --accent:#1c1d20;
  --ok:#0f6e56; --okbg:#e1f5ee; --err:#a32d2d; --errbg:#fceaea;
  --info:#185fa5; --infobg:#e6f1fb; --warnbg:#faeeda;
  --radius:10px; --radius-sm:7px;
}
*{box-sizing:border-box;}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;font-size:14px;line-height:1.5;}

/* Topbar */
.topbar{display:flex;align-items:center;gap:20px;background:var(--surface);
  border-bottom:1px solid var(--line);padding:0 20px;height:56px;position:sticky;top:0;z-index:10;flex-wrap:wrap;}
.brand{font-weight:600;display:flex;align-items:center;gap:8px;font-size:15px;}
.logo{width:28px;height:28px;border-radius:7px;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:600;}
.tabs{display:flex;gap:2px;flex:1;}
.tabs a{padding:8px 13px;color:var(--muted);text-decoration:none;border-radius:7px;font-size:13.5px;}
.tabs a:hover{background:var(--bg);}
.tabs a.on{color:var(--ink);font-weight:600;background:var(--bg);}
.user-chip{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted);}
.logout{color:var(--info);text-decoration:none;}

.content{max-width:1200px;margin:0 auto;padding:22px 20px 60px;}
h1{font-size:22px;font-weight:600;margin:0 0 16px;}
h3{font-size:15px;font-weight:600;margin:0 0 12px;}
h4{font-size:13px;font-weight:600;margin:0 0 8px;color:var(--muted);}

.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:4px;}
.page-head h1{margin:0;}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin-bottom:18px;}
.table-card{padding:14px;}

/* Forms */
label{font-size:12px;color:var(--muted);display:block;margin-bottom:3px;}
input,select,button{font-family:inherit;font-size:14px;}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select{
  height:38px;padding:0 11px;border:1px solid var(--line2);border-radius:var(--radius-sm);
  background:#fff;color:var(--ink);outline:none;width:100%;}
input:focus,select:focus{border-color:var(--info);box-shadow:0 0 0 3px var(--infobg);}
.row-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:nowrap;}
.row-form.wrap{flex-wrap:wrap;}
.row-form .field{flex:1;min-width:120px;}
.row-form input,.row-form select{width:auto;min-width:120px;}
.inline-chk{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);white-space:nowrap;}
.inline-chk input{width:auto;height:auto;}

button{cursor:pointer;}
.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent);
  height:38px;padding:0 18px;border-radius:var(--radius-sm);font-weight:500;}
.btn-primary:hover{opacity:.9;}
.btn-sm{background:#fff;border:1px solid var(--line2);color:var(--ink);
  padding:6px 11px;border-radius:6px;font-size:12.5px;}
.btn-sm:hover{background:var(--bg);}

/* Controls row */
.controls-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.gran-switch{display:flex;gap:5px;}
.gran-switch button{background:#fff;border:1px solid var(--line2);color:var(--muted);
  padding:6px 13px;border-radius:6px;font-size:13px;}
.gran-switch button.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.period-pick{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);flex-wrap:wrap;}
.period-pick input{width:auto;height:34px;}
.period-pick .sep{width:1px;height:24px;background:var(--line);margin:0 4px;}
.ic{font-size:13px;}

/* Cards grid (metrics) */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px;}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;}
.metric .ml{font-size:12px;color:var(--muted);margin-bottom:5px;}
.metric .mv{font-size:23px;font-weight:600;}
.metric .mk{font-size:11.5px;margin-top:5px;}
.metric .mk.ok{color:var(--ok);}
.metric .mk.err{color:var(--err);}

/* Legend */
.legend{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px;}
.legend .chk{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 9px;
  border-radius:6px;cursor:pointer;border:1px solid var(--line);user-select:none;background:#fff;}
.legend .chk.off{opacity:.45;}
.legend .chk .dot{width:10px;height:10px;border-radius:2px;display:inline-block;}
.legend .chk .auto{color:var(--muted);font-size:10px;}

.chart-wrap{position:relative;width:100%;height:340px;}

/* Tables */
.table-scroll{overflow-x:auto;}
table.grid,table.report{width:100%;border-collapse:collapse;}
table.grid th,table.grid td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;}
table.grid th{color:var(--muted);font-weight:600;}
table.report th,table.report td{padding:7px 10px;font-size:12px;text-align:right;white-space:nowrap;border-bottom:1px solid var(--line);}
table.report th:first-child,table.report td:first-child{text-align:left;position:sticky;left:0;background:var(--surface);font-weight:600;}
table.report th{color:var(--muted);font-weight:600;background:var(--surface);}
table.report tr.kpi-row td{background:var(--infobg);color:var(--info);font-weight:600;font-size:11px;}
table.report tr.kpi-row td:first-child{background:var(--infobg);}
.pos{color:var(--ok);} .neg{color:var(--err);}
.cell-ok{color:var(--ok);font-weight:600;} .cell-bad{color:var(--err);font-weight:600;}

/* Badges */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500;}
.badge.ok{background:var(--okbg);color:var(--ok);}
.badge.err{background:var(--errbg);color:var(--err);}
.badge.info{background:var(--infobg);color:var(--info);}
.badge.mut{background:var(--bg);color:var(--muted);}
.tag-auto{font-size:10px;color:var(--muted);background:var(--bg);padding:1px 6px;border-radius:4px;margin-left:4px;}

/* Indicators bifare */
.ind-group{margin-bottom:16px;}
.ind-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;}
.ind-chk{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink);
  padding:7px 10px;border:1px solid var(--line);border-radius:7px;background:#fff;cursor:pointer;margin:0;}
.ind-chk input{width:auto;height:auto;}
.indicators-form{margin-top:14px;}

/* Alerts */
.alert{padding:11px 14px;border-radius:8px;font-size:13px;margin-bottom:16px;background:var(--bg);border:1px solid var(--line);}
.alert.ok{background:var(--okbg);border-color:#c5e8da;color:var(--ok);}
.alert.err{background:var(--errbg);border-color:#f0caca;color:var(--err);}

.hint{font-size:12px;color:var(--muted);margin:8px 0 0;}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--muted);}
.muted-row{opacity:.55;}

/* Data entry */
.entry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:8px;}
.entry-grid .calc input{background:var(--bg);color:var(--muted);}
.entry-actions{display:flex;gap:10px;margin-top:16px;}
.recent-day{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;
  border:1px solid var(--line);border-radius:7px;margin-bottom:7px;background:#fff;}
.recent-day a{color:var(--info);text-decoration:none;font-size:13px;}

/* Inline actions (users) */
.inline-actions{position:relative;}
.inline-actions summary{list-style:none;display:inline-block;}
.inline-actions summary::-webkit-details-marker{display:none;}
.actions-pop{position:absolute;right:0;top:30px;background:#fff;border:1px solid var(--line2);
  border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px;z-index:5;min-width:200px;box-shadow:0 4px 16px rgba(0,0,0,.1);}
.actions-pop form{display:flex;gap:6px;}
.actions-pop input{height:32px;}

/* Login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);}
.login-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px;width:340px;}
.login-brand{display:flex;align-items:center;gap:9px;font-size:18px;font-weight:600;margin-bottom:22px;}
.login-card label{margin-top:12px;}
.login-card .btn-primary{width:100%;margin-top:20px;}
