/* ============================================================
   Mitrametrik — App shell & components (responsif, light/dark)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
svg{display:block}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:60;
}
.main{
  flex:1;min-width:0;margin-left:var(--sidebar-w);
  display:flex;flex-direction:column;min-height:100vh;
}
.content{padding:22px 26px;flex:1;display:flex;flex-direction:column;gap:var(--gap)}

/* ---------- Sidebar ---------- */
.sb-logo{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid var(--border)}
.sb-logo .mark{
  width:34px;height:34px;border-radius:9px;background:var(--accent-grad);
  display:grid;place-items:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px var(--accent-soft-2);
}
.sb-logo .mark svg{width:19px;height:19px}
.sb-logo .mark img{width:22px;height:22px;display:block}
.sb-logo .brand{display:flex;align-items:center;background:#fff;border-radius:8px;padding:6px 11px;overflow:hidden;flex-shrink:0}
.sb-logo .brand img{height:26px;width:auto;display:block}
.ico .bi{width:14px;height:14px;display:block}
.nsi .bi{width:13px;height:13px;display:block}
.sb-logo .name{font-size:16px;font-weight:800;letter-spacing:-0.3px}
.sb-nav{flex:1;overflow-y:auto;padding:10px 10px 4px}
.sb-group{font-size:10.5px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--muted);padding:14px 10px 6px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--text-2);font-size:13.5px;font-weight:500;cursor:pointer;
  margin-bottom:2px;transition:background .15s,color .15s;position:relative;
}
.nav-item svg{width:18px;height:18px;flex-shrink:0;stroke-width:2}
.nav-item:hover{background:var(--surface-3);color:var(--text)}
.nav-item.active{
  background:var(--accent-soft);color:var(--accent);font-weight:600;
  box-shadow:inset 3px 0 0 var(--accent);
}
.sb-user{
  display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border);
  cursor:pointer;
}
.sb-user .av{width:34px;height:34px;border-radius:50%;background:var(--accent-grad);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.sb-user .who{flex:1;min-width:0}
.sb-user .who b{font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user .who span{font-size:11px;color:var(--muted)}

/* ---------- Sidebar collapse toggle ---------- */
.sb-toggle-row{display:flex;justify-content:flex-end;padding:8px 12px;border-top:1px solid var(--border)}
.sb-toggle{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:grid;place-items:center;cursor:pointer;transition:all .15s;flex-shrink:0}
.sb-toggle:hover{color:var(--accent);border-color:var(--accent)}
.sb-toggle svg{width:16px;height:16px;transition:transform .2s}
body.sb-mini .sb-toggle svg{transform:rotate(180deg)}
body.sb-mini .sb-toggle-row{justify-content:center;padding:8px 6px}

/* Rail mode (desktop only) */
@media (min-width:1025px){
  .sidebar{transition:width .18s ease}
  .main{transition:margin-left .18s ease}
  body.sb-mini .sidebar{width:var(--sidebar-rail)}
  body.sb-mini .main{margin-left:var(--sidebar-rail)}
  body.sb-mini .sb-logo{justify-content:center;padding:18px 6px 14px}
  body.sb-mini .sb-logo .brand{width:36px;padding:6px 5px;justify-content:flex-start}
  body.sb-mini .sb-group{display:none}
  body.sb-mini .nav-item{justify-content:center;padding:10px 0;gap:0;font-size:0}
  body.sb-mini .nav-grp-hd{justify-content:center;padding:10px 0;gap:0}
  body.sb-mini .nav-grp-hd .ng-lbl,body.sb-mini .nav-grp-hd .ng-chev{display:none}
  body.sb-mini .nav-grp{position:relative}
  body.sb-mini .nav-grp>.nav-grp-body{display:none !important}
  body.sb-mini .nav-grp:hover>.nav-grp-body{display:block !important;position:absolute;left:calc(var(--sidebar-rail) - 2px);top:0;min-width:190px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:8px;margin:0;z-index:80}
  body.sb-mini .sb-user{justify-content:center;padding:12px 6px}
  body.sb-mini .sb-user .who{display:none}
}
@media (max-width:1024px){ .sb-toggle-row{display:none} }

/* ---------- Koneksi API panel ---------- */
.conn-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:9px;overflow:hidden}
.conn-hd{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;user-select:none;transition:background .15s}
.conn-hd:hover{background:var(--surface-3)}
.conn-name{flex:1;font-weight:600;font-size:13.5px;color:var(--text)}
.conn-chev{width:16px;height:16px;color:var(--muted);transition:transform .18s;flex-shrink:0}
.conn-item.open .conn-chev{transform:rotate(180deg)}
.conn-body{display:none;padding:2px 14px 16px;border-top:1px solid var(--border)}
.conn-item.open .conn-body{display:block}
.conn-field{margin-top:13px}
.conn-field label{display:block;font-size:12.5px;font-weight:600;color:var(--text-2);margin-bottom:4px}
.conn-field .hint{font-size:11px;color:var(--muted);margin-bottom:6px}
.conn-field input,.conn-field textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);font:inherit;font-size:13px;outline:none;resize:vertical}
.conn-field input:focus,.conn-field textarea:focus{border-color:var(--accent)}
.conn-actions{display:flex;align-items:center;gap:10px;margin-top:16px;flex-wrap:wrap}

/* ---------- Akun aktif (selector) ---------- */
.acct-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.acct-label{width:110px;font-size:13px;font-weight:600;color:var(--text-2);flex-shrink:0}
.acct-sel{flex:1;max-width:380px;height:38px;padding:0 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);font:inherit;font-size:13px;outline:none;cursor:pointer}
.acct-sel:focus{border-color:var(--accent)}

/* ---------- Demografi & geografi bars ---------- */
.demo-bar{display:flex;align-items:center;gap:12px;margin-bottom:11px}
.demo-bar .db-label{width:130px;flex-shrink:0;font-size:12.5px;color:var(--text-2);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.demo-bar .db-track{flex:1;height:8px;background:var(--surface-3);border-radius:6px;overflow:hidden}
.demo-bar .db-track>span{display:block;height:100%;border-radius:6px;background:var(--accent-grad)}
.demo-bar .db-val{width:84px;flex-shrink:0;text-align:right;font-size:12px;font-weight:700;color:var(--text)}

/* ---------- Post grid (konten) ---------- */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;padding:14px 16px}
.post-card{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-2);transition:box-shadow .15s}
.post-card:hover{box-shadow:var(--shadow-2)}
.post-card img,.post-card .no-thumb{width:100%;height:150px;object-fit:cover;display:block;background:var(--surface-3)}
.pc-body{padding:10px 11px}
.pc-cap{font-size:12.5px;color:var(--text);line-height:1.4;height:35px;overflow:hidden}
.pc-date{font-size:11px;color:var(--muted);margin:6px 0 8px}
.pc-link{color:var(--accent);text-decoration:none}
.pc-metrics{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:11px;color:var(--text-2)}
.pc-metrics b{color:var(--accent);font-weight:700}

/* ---------- Toast ---------- */
.toast{position:fixed;right:22px;bottom:22px;z-index:200;background:var(--surface);color:var(--text);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:10px;padding:12px 16px;font-size:13px;font-weight:600;box-shadow:var(--shadow);opacity:0;transform:translateY(12px);transition:opacity .25s,transform .25s;max-width:300px}
.toast.show{opacity:1;transform:translateY(0)}
.toast.ok{border-left-color:var(--pos)}
.toast.err{border-left-color:var(--neg)}

/* ---------- Modal konfirmasi ---------- */
.modal-back{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(15,13,23,0.5);opacity:0;transition:opacity .2s}
.modal-back.show{opacity:1}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 24px 64px rgba(0,0,0,0.35);width:100%;max-width:360px;padding:22px 22px 18px;transform:translateY(12px) scale(.97);transition:transform .2s}
.modal-back.show .modal{transform:translateY(0) scale(1)}
.modal-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:7px}
.modal-msg{font-size:13.5px;color:var(--text-2);line-height:1.55;margin-bottom:20px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px}
.btn.danger{background:var(--neg)}
.btn.danger:hover{background:#c13a44}

/* ---------- Topbar ---------- */
.topbar{
  height:var(--topbar-h);flex-shrink:0;position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--surface) 88%,transparent);
  backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:14px;padding:0 24px;
}
.tb-burger{display:none;width:38px;height:38px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.tb-title{font-size:13px;color:var(--muted);font-weight:500}
.tb-title b{color:var(--text);font-weight:700}
.tb-search{
  margin-left:auto;display:flex;align-items:center;gap:8px;
  background:var(--surface-3);border:1px solid var(--border);border-radius:10px;
  padding:0 12px;height:38px;width:260px;max-width:34vw;
}
.tb-search input{border:none;outline:none;background:none;color:var(--text);font:inherit;font-size:13px;width:100%}
.tb-search svg{width:16px;height:16px;color:var(--muted);flex-shrink:0}
.icon-btn{width:38px;height:38px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:all .15s}
.icon-btn:hover{color:var(--accent);border-color:var(--accent)}
.icon-btn svg{width:18px;height:18px}

/* ---------- Page header ---------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:2px}
.page-head h1{font-size:24px;font-weight:800;letter-spacing:-0.5px}
.page-head .sub{font-size:13px;color:var(--muted);margin-top:2px}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-2);overflow:hidden}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 18px;border-bottom:1px solid var(--border)}
.card-head h2{font-size:15px;font-weight:700}
.card-body{padding:18px}

/* ---------- Scorecards ---------- */
.scards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.scard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-2);position:relative}
.scard .lbl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:9px;display:flex;align-items:center;gap:6px}
.scard .val{font-size:clamp(20px,2.1vw,28px);font-weight:800;color:var(--accent);letter-spacing:-0.6px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scard .delta{display:inline-flex;align-items:center;gap:4px;margin-top:10px;font-size:12px;font-weight:700}
.scard .delta svg{width:13px;height:13px}
.delta.up{color:var(--pos)} .delta.down{color:var(--neg)}

/* ---------- Grid rows ---------- */
.row{display:grid;gap:var(--gap)}
.row.c2{grid-template-columns:1fr 1fr}
.row.c3{grid-template-columns:2fr 1fr}

/* ---------- Tables ---------- */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{text-align:left;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}
table.tbl td{padding:11px 12px;border-bottom:1px solid var(--border);white-space:nowrap}
table.tbl tr:last-child td{border-bottom:none}
table.tbl tbody tr:hover{background:var(--surface-2)}
.plat{display:flex;align-items:center;gap:9px;font-weight:600}
.plat .ico{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;flex-shrink:0;font-size:12px;font-weight:800;color:#fff}
.val-accent{color:var(--accent);font-weight:700}

/* ---------- Badges / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}
.badge.ok{background:rgba(31,157,87,0.12);color:var(--pos)}
.badge.warn{background:rgba(201,138,26,0.14);color:var(--warn)}
.badge.err{background:rgba(214,69,80,0.12);color:var(--neg)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9px;border:1px solid var(--border);background:var(--surface);font-size:12.5px;font-weight:600;cursor:pointer}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px;border-radius:10px;border:1px solid transparent;background:var(--accent);color:var(--on-accent);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.btn:hover{background:var(--accent-2)}
.btn.ghost{background:var(--surface);border-color:var(--border);color:var(--text-2)}
.btn.ghost:hover{color:var(--accent);border-color:var(--accent)}
.btn.sm{height:30px;padding:0 12px;font-size:12px}
.btn svg{width:16px;height:16px}

/* ---------- Funnel (CRM) ---------- */
.funnel{display:flex;align-items:stretch;gap:8px;flex-wrap:wrap}
.fn-step{flex:1;min-width:118px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center}
.fn-val{font-size:22px;font-weight:800;color:var(--accent);letter-spacing:-0.5px}
.fn-lbl{font-size:12px;color:var(--muted);margin-top:5px}
.fn-arrow{display:flex;align-items:center;color:var(--muted)}

/* ---------- Data sources ---------- */
.mode{display:inline-block;padding:2px 9px;border-radius:7px;background:var(--surface-3);color:var(--text-2);font-size:11px;font-weight:700}
.muted-td{color:var(--muted);font-size:12px;white-space:normal}
.toggle{display:inline-block;width:36px;height:20px;border-radius:20px;background:var(--border);position:relative;transition:background .15s;cursor:pointer}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .15s;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.toggle.on{background:var(--accent)}
.toggle.on::after{left:18px}

/* ---------- Settings ---------- */
.set-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.set-row:last-child{border-bottom:none}
.set-row b{font-size:13.5px}
.seg{display:flex;border:1px solid var(--border);border-radius:9px;overflow:hidden}
.seg-btn{padding:7px 14px;background:var(--surface);border:none;color:var(--text-2);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer}
.seg-btn.active{background:var(--accent);color:var(--on-accent)}
.swatch{width:30px;height:30px;border-radius:8px;border:1px solid var(--border)}

/* ---------- Sidebar groups (expandable) ---------- */
.nav-grp{margin-bottom:1px}
.nav-grp-hd{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;user-select:none}
.nav-grp-hd:hover{background:var(--surface-3);color:var(--text)}
.nav-grp-hd .ng-ico{display:flex;flex-shrink:0}
.nav-grp-hd .ng-ico svg{width:18px;height:18px}
.nav-grp-hd .ng-lbl{flex:1}
.nav-grp-hd .ng-chev{display:flex;color:var(--muted);transition:transform .18s}
.nav-grp-hd .ng-chev svg{width:15px;height:15px}
.nav-grp.open>.nav-grp-hd .ng-chev{transform:rotate(90deg)}
.nav-grp.open>.nav-grp-hd{color:var(--text)}
.nav-grp-body{display:none;padding:2px 0 4px 12px;margin-left:18px;border-left:1px solid var(--border)}
.nav-grp.open>.nav-grp-body{display:block}
.nav-sub{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;margin-bottom:1px;transition:background .15s,color .15s}
.nav-sub:hover{background:var(--surface-3);color:var(--text)}
.nav-sub.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.nsi{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;font-size:9.5px;font-weight:800;color:#fff;line-height:1}
.nsi.ov{background:var(--surface-3);color:var(--muted)}
.nsi svg{width:12px;height:12px}

/* ---------- Input Data form ---------- */
.inp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:13px}
.inp-field label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.inp-field input{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);font:inherit;font-size:13.5px;outline:none}
.inp-field input:focus{border-color:var(--accent)}
.upl{border:1.5px dashed var(--border-2);border-radius:var(--radius-sm);padding:22px;text-align:center;color:var(--muted);font-size:13px;margin-top:14px}
.upl svg{width:26px;height:26px;margin-bottom:8px;color:var(--accent)}

/* ---------- Target cards ---------- */
.tgt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap)}
.tgt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-2)}
.tgt-card .tl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.tgt-card .tv{font-size:20px;font-weight:800;color:var(--text);margin:7px 0 2px}
.tgt-card .tof{font-size:12px;color:var(--muted)}
.tgt-bar{height:7px;border-radius:6px;background:var(--surface-3);margin-top:11px;overflow:hidden}
.tgt-bar>span{display:block;height:100%;border-radius:6px;background:var(--accent-grad)}
.tgt-pct{font-size:12px;font-weight:700;color:var(--accent);margin-top:7px}

/* ---------- Sub-tabs (channel > satuan) ---------- */
.subtabs{display:flex;gap:2px;border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}
.subtab{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-2);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;cursor:pointer;transition:color .15s}
.subtab:hover{color:var(--text)}
.subtab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* ---------- Mobile drawer ---------- */
.sb-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:55}

@media (max-width:1024px){
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow)}
  body.nav-open .sidebar{transform:translateX(0)}
  body.nav-open .sb-backdrop{display:block}
  .main{margin-left:0}
  .tb-burger{display:flex}
}
@media (max-width:960px){
  .row.c2,.row.c3{grid-template-columns:1fr}
  .scards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .content{padding:16px 14px}
  .tb-search{display:none}
  .page-head h1{font-size:20px}
}
