/* =========================================================================
   dewa-scan-wa — Operator Console UI
   Design system: compact, utilitarian, dark. Archivo + JetBrains Mono.
   ========================================================================= */

/* ---------- Design tokens ---------- */
:root{
  /* surfaces */
  --bg:        #0a0c10;
  --surface-1: #10131a;
  --surface-2: #151922;
  --surface-3: #1b202b;
  --border:    #232a36;
  --border-2:  #313a49;

  /* text */
  --text:      #e8ecf2;
  --text-dim:  #99a3b2;
  --text-faint:#606a7a;

  /* accents */
  --accent:     #10b981;   /* emerald — primary/connected */
  --accent-soft:#0e3a2f;
  --accent-fg:  #052e22;
  --blue:       #38bdf8;   /* API / info */
  --blue-soft:  #0e2f44;
  --amber:      #f6b73c;
  --amber-soft: #3a2c0e;
  --danger:     #f3666e;
  --danger-soft:#3a1417;

  /* type */
  --font-ui:  'Archivo', ui-sans-serif, system-ui, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* metrics */
  --fs-xs: 10.5px;
  --fs-sm: 11.5px;
  --fs-base: 13px;
  --fs-md: 14px;
  --fs-lg: 17px;
  --fs-xl: 22px;

  --sp-1: 4px;  --sp-2: 6px;  --sp-3: 8px;  --sp-4: 12px;
  --sp-5: 16px; --sp-6: 20px; --sp-7: 28px;

  --r-sm: 5px; --r-md: 7px; --r-lg: 10px;
  --ctrl-h: 30px;            /* tinggi standar kontrol */
  --ctrl-h-sm: 25px;

  --shadow: 0 8px 24px rgba(0,0,0,.4);
  --ring: 0 0 0 2px rgba(16,185,129,.35);

  /* konten memenuhi lebar layar; gutter = jarak tepi kiri/kanan saja */
  --gutter: 28px;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--font-ui);
  font-size:var(--fs-base);
  line-height:1.45;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  letter-spacing:.1px;
}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.2px}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:var(--font-mono);font-size:.9em;background:var(--surface-3);padding:1px 5px;border-radius:4px;color:#9fd}
.mono{font-family:var(--font-mono)}
.dim{color:var(--text-dim)}
.faint{color:var(--text-faint)}
.hidden{display:none!important}

/* ---------- Scrollbars ---------- */
*{scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#3f4a5c;border:2px solid transparent;background-clip:padding-box}

/* ---------- Layout primitives ---------- */
.row{display:flex;align-items:center;gap:var(--sp-3)}
.row.wrap{flex-wrap:wrap}
.row.between{justify-content:space-between}
.row.end{justify-content:flex-end}
.grow{flex:1}
.stack{display:flex;flex-direction:column;gap:var(--sp-4)}

/* =========================================================================
   STANDARD: Buttons
   ========================================================================= */
.btn{
  --b-bg:var(--surface-3); --b-fg:var(--text); --b-bd:var(--border-2);
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  height:var(--ctrl-h);padding:0 12px;
  font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:600;
  letter-spacing:.2px;white-space:nowrap;
  background:var(--b-bg);color:var(--b-fg);
  border:1px solid var(--b-bd);border-radius:var(--r-sm);
  cursor:pointer;transition:background .13s,border-color .13s,transform .04s,opacity .13s;
}
.btn:hover{background:color-mix(in srgb,var(--b-bg) 80%,#fff 8%)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn svg,.btn .ico{font-size:13px;line-height:1}
.btn-primary{--b-bg:var(--accent);--b-fg:var(--accent-fg);--b-bd:transparent;font-weight:700}
.btn-primary:hover{background:#13c98f}
.btn-danger{--b-bg:transparent;--b-fg:var(--danger);--b-bd:var(--danger-soft)}
.btn-danger:hover{background:var(--danger-soft)}
.btn-ghost{--b-bg:transparent;--b-bd:var(--border)}
.btn-sm{height:var(--ctrl-h-sm);padding:0 9px;font-size:var(--fs-xs)}
.btn-block{width:100%}
.btn-icon{width:var(--ctrl-h);padding:0}

/* =========================================================================
   STANDARD: Form controls
   ========================================================================= */
.field-label{display:block;font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;
  letter-spacing:.6px;color:var(--text-dim);margin-bottom:var(--sp-2)}
.input,textarea.input{
  width:100%;height:var(--ctrl-h);padding:0 11px;
  font-family:var(--font-ui);font-size:var(--fs-base);color:var(--text);
  background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);
  outline:none;transition:border-color .13s,box-shadow .13s;
}
textarea.input{height:auto;padding:9px 11px;resize:vertical;line-height:1.55}
textarea.mono{font-family:var(--font-mono);font-size:12.5px}
.input::placeholder{color:var(--text-faint)}
.input:focus{border-color:var(--accent);box-shadow:var(--ring)}

/* =========================================================================
   STANDARD: Tags / badges
   ========================================================================= */
.tag{display:inline-flex;align-items:center;gap:4px;
  height:18px;padding:0 7px;border-radius:99px;
  font-family:var(--font-ui);font-size:var(--fs-xs);font-weight:700;
  letter-spacing:.3px;text-transform:uppercase;
  background:var(--surface-3);color:var(--text-dim);border:1px solid var(--border-2)}
.tag-green{background:var(--accent-soft);color:#5ee9b5;border-color:#155e48}
.tag-blue{background:var(--blue-soft);color:#7fd3f7;border-color:#1d4d68}
.tag-amber{background:var(--amber-soft);color:#f3c065;border-color:#5a4416}
.tag-red{background:var(--danger-soft);color:#f59aa0;border-color:#5e2024}
.tag-gray{background:var(--surface-3);color:var(--text-dim);border-color:var(--border-2)}
.dot{width:7px;height:7px;border-radius:99px;display:inline-block;flex:none}
.dot-green{background:var(--accent);box-shadow:0 0 6px rgba(16,185,129,.7)}
.dot-amber{background:var(--amber)}
.dot-red{background:var(--danger)}
.dot-gray{background:var(--text-faint)}

/* =========================================================================
   STANDARD: Panel / card
   ========================================================================= */
.panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg)}
.panel-pad{padding:var(--sp-5)}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  padding:10px var(--sp-5);border-bottom:1px solid var(--border)}
.panel-title{font-size:var(--fs-sm);font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-dim)}

/* =========================================================================
   STANDARD: Table
   ========================================================================= */
.tbl-scroll{overflow:auto;border-radius:var(--r-md);border:1px solid var(--border)}
table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}
table.tbl th,table.tbl td{text-align:left;padding:6px 11px;border-bottom:1px solid var(--border);white-space:nowrap}
table.tbl thead th{position:sticky;top:0;z-index:2;
  background:var(--surface-2);
  font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  color:var(--text-dim);padding-top:8px;padding-bottom:8px}
table.tbl thead th::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--border-2)}
table.tbl tbody tr:nth-child(even) td{background:rgba(255,255,255,.012)}
table.tbl tbody tr:hover td{background:rgba(56,189,248,.06)}
table.tbl tbody tr:last-child td{border-bottom:0}
table.tbl td.num{font-family:var(--font-mono);color:var(--text-dim);text-align:right;width:1%}
table.tbl td.phone{font-family:var(--font-mono);letter-spacing:.3px}
table.tbl td.name b{font-weight:600}
.cell-link{max-width:230px;overflow:hidden;text-overflow:ellipsis;display:inline-block;vertical-align:bottom}

/* sortable headers */
table.tbl th.sortable{cursor:pointer;user-select:none;transition:color .12s}
table.tbl th .th-in{display:inline-flex;align-items:center;gap:5px}
table.tbl th .sort-ar{font-size:9px;line-height:1;opacity:.35;transition:opacity .12s,color .12s}
table.tbl th.sortable:hover{color:var(--text)}
table.tbl th.sortable:hover .sort-ar{opacity:.7}
table.tbl th.sorted{color:var(--accent)}
table.tbl th.sorted .sort-ar{opacity:1;color:var(--accent)}
table.tbl td.res-cell,table.tbl td.col-act,table.tbl th.col-act,table.tbl td.named-cell{white-space:nowrap}
table.tbl td.res-cell .hit{font-family:var(--font-mono);color:var(--accent);font-weight:700}
table.tbl td.named-cell .tag{font-family:var(--font-mono)}

/* =========================================================================
   APP SHELL
   ========================================================================= */
.app{display:grid;grid-template-columns:206px 1fr;height:100vh;overflow:hidden}

/* Sidebar */
.sidebar{display:flex;flex-direction:column;background:var(--surface-1);border-right:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:9px;padding:14px var(--sp-5) 12px}
.brand-logo{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;flex:none;
  background:linear-gradient(135deg,var(--accent),#0c8f6a);color:var(--accent-fg);font-size:15px;
  box-shadow:0 2px 10px rgba(16,185,129,.35)}
.brand-name{font-size:var(--fs-md);font-weight:700;letter-spacing:-.3px}
.brand-name small{display:block;font-size:9px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--text-faint);margin-top:1px}

.nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-sm);
  color:var(--text-dim);font-size:var(--fs-base);font-weight:500;cursor:pointer;
  border:1px solid transparent;transition:background .12s,color .12s}
.nav-item .ico{width:16px;text-align:center;font-size:14px;opacity:.85}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:var(--surface-3);color:var(--text);border-color:var(--border-2)}
.nav-item.active .ico{opacity:1}

.nav-section{font-size:9px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--text-faint);padding:10px 14px 4px}

.sidebar-foot{margin-top:auto;padding:12px var(--sp-4);border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:9px}
.conn-pill{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--r-sm);
  background:var(--surface-2);border:1px solid var(--border);font-size:var(--fs-sm)}
.conn-pill .lbl{color:var(--text-dim)}
.conn-pill b{font-family:var(--font-mono);margin-left:auto}

/* Main */
.main{display:flex;flex-direction:column;overflow:hidden}
.view{display:flex;flex-direction:column;overflow:hidden;height:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--sp-4);
  padding:16px var(--gutter) 14px;border-bottom:1px solid var(--border);flex:none}
.page-head h2{font-size:var(--fs-xl);letter-spacing:-.5px}
.page-head .sub{font-size:var(--fs-sm);color:var(--text-dim);margin-top:3px;max-width:60ch}
/* page-body TIDAK ikut scroll; scroll terjadi di dalam area konten masing-masing */
.page-body{padding:var(--sp-5) var(--gutter) var(--sp-7);overflow:hidden;flex:1;
  min-height:0;display:flex;flex-direction:column}

/* History & Accounts: konten scroll di dalam, halaman tetap fixed */
#view-history .tbl-scroll{flex:1;min-height:0}
#view-accounts .acc-grid{flex:1;min-height:0;overflow:auto;align-content:start;padding-bottom:2px}

/* =========================================================================
   CHECK view  — dua kolom kiri/kanan, tinggi sama (simetris), fixed height
   ========================================================================= */
/* kiri sempit (nomor cuma sebaris), kanan lebar untuk tabel result */
.check-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:var(--sp-5);
  flex:1;min-height:0;align-items:stretch}

/* kolom kiri: input memenuhi tinggi, textarea yang scroll */
#inputPanel{display:flex;flex-direction:column;min-width:0;min-height:0}
#inputPanel #numbers{flex:1;min-height:140px;resize:none;overflow:auto}

/* kolom kanan: result memenuhi tinggi, daftar (tabel) yang scroll */
#resultPanel{display:flex;flex-direction:column;min-width:0;min-height:0}
#resultPanel .panel-pad{display:flex;flex-direction:column;min-height:0;flex:1}
/* hanya scroll vertikal; tabel fit ke lebar, kolom panjang membungkus */
#resultPanel .tbl-scroll{flex:1;min-height:0;overflow-x:hidden}
#resultTable{table-layout:fixed;width:100%}
#resultTable th,#resultTable td{white-space:normal;overflow-wrap:anywhere;word-break:break-word}
#resultTable td.num,#resultTable td.phone{white-space:nowrap}
#resultTable .cell-link{max-width:100%}
/* proporsi kolom tabel result (total 100%) */
#resultTable .col-idx{width:38px}
#resultTable th:nth-child(2){width:15%}  /* Nomor */
#resultTable th:nth-child(3){width:22%}  /* Nama Bisnis */
#resultTable th:nth-child(4){width:12%}  /* Tipe */
#resultTable th:nth-child(5){width:17%}  /* Kategori */
#resultTable th:nth-child(6){width:20%}  /* Website */
#resultTable th:nth-child(7){width:14%}  /* Status */

@media(max-width:900px){
  .check-grid{grid-template-columns:1fr}
}

.input-foot{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-top:10px}
.count-badge{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text-dim)}
.count-badge b{color:var(--accent);font-size:var(--fs-md)}

/* progress */
.bar{height:6px;background:var(--bg);border-radius:99px;overflow:hidden;border:1px solid var(--border)}
.bar-fill{height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--blue),var(--accent));transition:width .35s ease}
.prog-meta{display:flex;justify-content:space-between;align-items:center;font-size:var(--fs-sm);color:var(--text-dim);margin-top:7px}
.prog-meta .mono{color:var(--text)}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin:var(--sp-4) 0}
.stat{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);
  padding:9px 12px;border-left:3px solid var(--border-2)}
.stat .v{font-family:var(--font-mono);font-size:var(--fs-xl);font-weight:700;line-height:1.1}
.stat .k{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-top:2px}
.stat.s-named{border-left-color:var(--accent)}.stat.s-named .v{color:#5ee9b5}
.stat.s-unnamed{border-left-color:var(--blue)}.stat.s-unnamed .v{color:#7fd3f7}
.stat.s-regular{border-left-color:var(--text-faint)}
.stat.s-none{border-left-color:var(--danger)}.stat.s-none .v{color:#f59aa0}

/* segmented filter */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--r-md);padding:3px;gap:2px;flex-wrap:wrap}
.seg-btn{border:0;background:transparent;color:var(--text-dim);
  padding:5px 11px;border-radius:var(--r-sm);font-family:var(--font-ui);
  font-size:var(--fs-sm);font-weight:600;cursor:pointer;transition:background .12s,color .12s}
.seg-btn:hover{color:var(--text)}
.seg-btn.active{background:var(--surface-3);color:var(--text);box-shadow:inset 0 0 0 1px var(--border-2)}

/* =========================================================================
   ACCOUNTS view
   ========================================================================= */
.acc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--sp-4)}
.acc-card{position:relative;background:var(--surface-1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:14px}
.acc-card .avatar{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:var(--surface-3);font-size:16px;margin-bottom:9px}
.acc-card .a-label{font-size:var(--fs-md);font-weight:600}
.acc-card .a-phone{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text-dim);margin-top:1px}
.acc-card .a-del{position:absolute;top:9px;right:9px;width:22px;height:22px;border-radius:5px;
  display:grid;place-items:center;background:transparent;border:1px solid transparent;
  color:var(--text-faint);cursor:pointer;font-size:13px;transition:.12s}
.acc-card .a-del:hover{background:var(--danger-soft);color:var(--danger);border-color:#5e2024}
.acc-card .a-status{display:flex;align-items:center;gap:7px;margin-top:11px;font-size:var(--fs-sm)}
.acc-card.add{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;border-style:dashed;border-color:var(--border-2);color:var(--text-dim);
  cursor:pointer;min-height:120px;transition:.12s}
.acc-card.add:hover{border-color:var(--accent);color:var(--accent);background:var(--surface-2)}
.acc-card.add .plus{font-size:24px;font-weight:300}

/* =========================================================================
   LOGIN
   ========================================================================= */
.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:
    radial-gradient(700px 360px at 70% -5%,rgba(16,185,129,.12),transparent 70%),
    radial-gradient(600px 400px at 10% 110%,rgba(56,189,248,.08),transparent 70%),
    var(--bg);
}
.login-card{width:340px;background:var(--surface-1);border:1px solid var(--border);
  border-radius:14px;padding:28px 26px 24px;box-shadow:var(--shadow)}
.login-brand{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:22px;text-align:center}
.login-brand .brand-logo{width:42px;height:42px;border-radius:11px;font-size:22px}
.login-brand h1{font-size:19px;letter-spacing:-.4px}
.login-brand p{font-size:var(--fs-sm);color:var(--text-dim);margin:0}
.login-card .field-label{margin-top:4px}
.login-card .input{height:34px;font-family:var(--font-mono);letter-spacing:1px;text-align:center}
.login-card .btn{margin-top:16px;height:36px}
.err{color:#f59aa0;font-size:var(--fs-sm);margin-top:10px;min-height:16px;text-align:center}
.hint{font-size:var(--fs-xs);color:var(--text-faint);text-align:center;margin-top:14px}

/* =========================================================================
   MODAL
   ========================================================================= */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;
  background:rgba(5,7,11,.74);backdrop-filter:blur(3px)}
.modal-card{width:330px;background:var(--surface-1);border:1px solid var(--border);
  border-radius:14px;padding:22px;text-align:center;box-shadow:var(--shadow)}
.modal-card h3{font-size:var(--fs-lg)}
.modal-card .sub{font-size:var(--fs-sm);color:var(--text-dim);margin:4px 0 0}
.qr-holder{width:236px;height:236px;margin:16px auto;border-radius:12px;background:#fff;
  display:grid;place-items:center;overflow:hidden}
.qr-holder img{width:100%;height:100%}
.spinner{width:30px;height:30px;border:3px solid #cbd5e1;border-top-color:var(--accent);
  border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* empty state */
.empty{padding:40px 16px;text-align:center;color:var(--text-faint);font-size:var(--fs-base)}
.empty .ico{font-size:26px;display:block;margin-bottom:8px;opacity:.6}

/* =========================================================================
   ADMIN: Kelola Token (/generate)
   ========================================================================= */
/* link menu eksternal di sidebar app (Kelola Token) */
.nav-ext,.nav-ext:hover{text-decoration:none}

.gen-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  padding:10px var(--gutter);border-bottom:1px solid var(--border);background:var(--surface-1);flex:none}
.topbar .brand{padding:0}
.gen-main{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.gen-main .tbl-scroll{flex:1;min-height:0}

.create-form{gap:var(--sp-3)}
.create-form .input{width:240px}

/* token tampil sekali */
.token-show{margin:14px 0;padding:13px;background:var(--bg);border:1px dashed var(--border-2);
  border-radius:var(--r-md);font-size:15px;letter-spacing:1.5px;word-break:break-all;
  color:var(--accent);text-align:center}
.modal-card.modal-wide{width:560px;max-width:92vw;text-align:left}
.log-scroll{max-height:52vh;margin-top:12px}
.danger-link{color:var(--danger)!important}
#tokenTable td.col-act a,#tokenTable .col-act{white-space:nowrap}
#tokenTable .col-idx{width:34px}
#tokenTable td.flag-cell{white-space:nowrap}
td.ua{white-space:normal;max-width:300px;overflow-wrap:anywhere;font-size:11px;color:var(--text-dim)}

@media(max-width:760px){
  .create-form{width:100%;margin-top:10px}
  .create-form .input{flex:1;width:auto}
  .gen-main .page-body{overflow:auto}
  .gen-main .tbl-scroll{flex:none}
}

/* =========================================================================
   TIPS (callout badge warna-warni) & TOAST notifikasi
   ========================================================================= */
/* chip ringkas — sebaris horizontal di bawah header, hemat ruang */
.tips{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4)}
.tip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;
  font-size:var(--fs-xs);line-height:1.3;color:var(--text-dim);
  background:var(--surface-2);border:1px solid var(--border);white-space:nowrap}
.tip b{color:var(--text);font-weight:600}
.tip .tip-badge{flex:none;display:inline-flex;align-items:center;height:15px;padding:0 6px;
  border-radius:99px;font-size:9.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.tip-info{border-color:#1a4760}    .tip-info  .tip-badge{background:var(--blue-soft);color:#7fd3f7}
.tip-ok{border-color:#15543f}      .tip-ok    .tip-badge{background:var(--accent-soft);color:#5ee9b5}
.tip-warn{border-color:#54401a}    .tip-warn  .tip-badge{background:var(--amber-soft);color:#f3c065}
.tip-danger{border-color:#552025}  .tip-danger .tip-badge{background:var(--danger-soft);color:#f59aa0}
@media(max-width:760px){.tip{white-space:normal}}

/* toast */
.toast-wrap{position:fixed;top:14px;right:14px;z-index:90;display:flex;flex-direction:column;
  gap:8px;max-width:340px;pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:9px;padding:10px 12px;
  border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border-2);
  border-left-width:3px;box-shadow:var(--shadow);font-size:var(--fs-sm);color:var(--text);
  transition:opacity .2s ease;animation:toastIn .22s ease}
.toast .t-ico{flex:none;width:18px;height:18px;border-radius:99px;display:grid;place-items:center;
  font-size:11px;font-weight:700;margin-top:1px}
.toast.ok  {border-left-color:var(--accent)} .toast.ok  .t-ico{background:var(--accent-soft);color:#5ee9b5}
.toast.info{border-left-color:var(--blue)}   .toast.info .t-ico{background:var(--blue-soft);color:#7fd3f7}
.toast.warn{border-left-color:var(--amber)}  .toast.warn .t-ico{background:var(--amber-soft);color:#f3c065}
.toast.err {border-left-color:var(--danger)} .toast.err .t-ico{background:var(--danger-soft);color:#f59aa0}
@keyframes toastIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}

/* kontrol kecepatan scan */
.speed-row{margin-top:10px;gap:var(--sp-3);flex-wrap:wrap}
.speed-label{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-sm);color:var(--text-dim)}
.mini-select{height:var(--ctrl-h-sm);padding:0 8px;font-family:var(--font-ui);font-size:var(--fs-sm);
  font-weight:600;color:var(--text);background:var(--surface-3);border:1px solid var(--border-2);
  border-radius:var(--r-sm);cursor:pointer;outline:none}
.mini-select:focus{border-color:var(--accent);box-shadow:var(--ring)}
.speed-hint{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-faint)}

/* entrance */
.view{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

@media(max-width:760px){
  .app{grid-template-columns:1fr;height:auto;overflow:auto}
  .sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;border-right:0;border-bottom:1px solid var(--border)}
  .nav{flex-direction:row;flex-wrap:wrap}
  .sidebar-foot{margin:0;border-top:0;flex-direction:row}
  .page-head,.page-body{padding-left:var(--sp-5);padding-right:var(--sp-5)}
  .stats{grid-template-columns:repeat(2,1fr)}
  /* mobile: kembalikan alur natural (scroll halaman) */
  .view{height:auto;overflow:visible}
  .page-body{overflow:visible;display:block}
  .check-grid{display:block}
  #inputPanel,#resultPanel{display:block}
  #inputPanel #numbers{min-height:200px}
  #inputPanel{margin-bottom:var(--sp-5)}
  #resultPanel .tbl-scroll,#view-history .tbl-scroll{max-height:60vh}
}
