:root{
    --sidebar-bg:#0f172a;        /* slate-900 */
    --sidebar-bg-2:#111c33;
    --sidebar-line:#1e293b;
    --sidebar-text:#cbd5e1;
    --sidebar-dim:#64748b;
    --bg:#f1f5f9;                /* slate-100 */
    --panel:#ffffff;
    --ink:#0f172a;
    --ink-2:#334155;
    --ink-3:#64748b;
    --line:#e2e8f0;
    --line-2:#eef2f7;
    --indigo:#4f46e5;
    --indigo-soft:#eef2ff;
    --cyan:#0891b2;
    --cyan-soft:#ecfeff;
    --emerald:#059669;
    --emerald-soft:#ecfdf5;
    --amber:#b45309;
    --amber-soft:#fffbeb;
    --rose:#be123c;
    --rose-soft:#fff1f2;
    --zebra:#f8fafc;
    --radius:10px;
    --shadow-sm:0 1px 2px rgba(15,23,42,.06);
    --shadow:0 4px 16px -4px rgba(15,23,42,.12),0 2px 6px -2px rgba(15,23,42,.06);
    --shadow-lg:0 24px 60px -12px rgba(15,23,42,.35);
    --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono","Courier New",monospace;
    --sans:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
  }
  *{box-sizing:border-box}
  html,body{height:100%}
  body{
    margin:0;font-family:var(--sans);
    background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;
    -webkit-font-smoothing:antialiased;
  }
  button{font-family:inherit}
  ::selection{background:#c7d2fe}

  /* ---------- prototype bar ---------- */
  .proto-bar{
    display:flex;align-items:center;gap:14px;flex-wrap:wrap;
    background:#0b1222;color:#94a3b8;font-size:11.5px;letter-spacing:.02em;
    padding:6px 16px;border-bottom:1px solid #1e293b;
  }
  .proto-bar b{color:#e2e8f0;font-weight:600}
  .proto-bar .tag{
    font-family:var(--mono);background:#1e293b;color:#7dd3fc;
    padding:1px 7px;border-radius:5px;font-size:10.5px;
  }
  .proto-bar .spacer{flex:1}
  .proto-bar label{display:inline-flex;align-items:center;gap:6px;color:#94a3b8}
  .proto-bar select{
    background:#111c33;color:#e2e8f0;border:1px solid #334155;border-radius:6px;
    padding:3px 8px;font-family:inherit;font-size:11.5px;
  }

  /* ---------- topbar ---------- */
  .topbar{
    display:flex;align-items:center;gap:18px;
    background:linear-gradient(180deg,#13203b,#0f172a);
    color:#e2e8f0;padding:0 18px;height:56px;border-bottom:1px solid #0b1222;
  }
  .brand{display:flex;align-items:center;gap:11px;font-weight:600;letter-spacing:-.01em}
  .brand .logo{
    width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
    background:linear-gradient(135deg,var(--indigo),#06b6d4);box-shadow:0 2px 10px rgba(79,70,229,.5);
    font-family:var(--mono);font-weight:600;font-size:15px;color:#fff;
  }
  .brand .sub{font-size:11px;color:#7c8ba5;font-weight:500;margin-top:1px}
  .topbar .spacer{flex:1}
  .badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .badge{
    display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 10px;
    border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:.02em;cursor:default;
    border:1px solid transparent;white-space:nowrap;
  }
  .badge .dot{width:7px;height:7px;border-radius:50%}
  .badge-view{background:rgba(5,150,105,.14);color:#6ee7b7;border-color:rgba(16,185,129,.3)}
  .badge-view .dot{background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.18)}
  .badge-read{background:rgba(8,145,178,.14);color:#7dd3fc;border-color:rgba(14,165,233,.3)}
  .badge-read .dot{background:#38bdf8}
  .badge-conn{background:rgba(79,70,229,.16);color:#c7d2fe;border-color:rgba(99,102,241,.32);cursor:pointer}
  .badge-conn.prod{background:rgba(180,83,9,.16);color:#fcd34d;border-color:rgba(217,119,6,.32)}
  .badge-conn .dot{background:#818cf8}
  .badge-conn.prod .dot{background:#fbbf24}
  .userchip{display:flex;align-items:center;gap:10px;padding:5px 8px 5px 10px;border-radius:10px;border:1px solid #243049;background:#0e1830}
  .userchip .av{width:28px;height:28px;border-radius:8px;background:#1e293b;display:grid;place-items:center;font-weight:600;color:#cbd5e1;font-size:12px}
  .userchip .nm{font-size:12.5px;font-weight:600;color:#e2e8f0;line-height:1.1}
  .userchip .org{font-size:10.5px;color:#7c8ba5;font-family:var(--mono)}

  /* ---------- shell ---------- */
  .shell{display:grid;grid-template-columns:286px 1fr;height:calc(100vh - 56px - 31px)}
  @media(max-width:900px){.shell{grid-template-columns:1fr}.sidebar{display:none}}

  /* ---------- sidebar ---------- */
  .sidebar{background:var(--sidebar-bg);border-right:1px solid #0b1222;display:flex;flex-direction:column;overflow:hidden}
  .side-sec{padding:14px 14px 10px}
  .side-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--sidebar-dim);font-weight:600;margin-bottom:8px}
  .db-switch{position:relative}
  .db-current{
    width:100%;text-align:left;background:var(--sidebar-bg-2);border:1px solid var(--sidebar-line);
    color:var(--sidebar-text);padding:9px 11px;border-radius:9px;cursor:pointer;
    display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;
  }
  .db-current .ic{color:#7dd3fc}
  .db-current .chev{margin-left:auto;color:var(--sidebar-dim);transition:transform .18s}
  .db-switch.open .chev{transform:rotate(180deg)}
  .db-list{list-style:none;margin:8px 0 0;padding:0;display:none}
  .db-switch.open .db-list{display:block}
  .db-list li{
    padding:8px 11px;border-radius:8px;cursor:pointer;color:var(--sidebar-text);
    display:flex;flex-direction:column;gap:1px;
  }
  .db-list li:hover{background:var(--sidebar-bg-2)}
  .db-list li.active{background:rgba(79,70,229,.18);color:#fff}
  .db-list li .nm{font-size:13px;font-weight:500}
  .db-list li .ds{font-size:10.5px;color:var(--sidebar-dim)}

  .tbl-search-wrap{position:relative;margin-bottom:6px}
  .tbl-search{
    width:100%;background:var(--sidebar-bg-2);border:1px solid var(--sidebar-line);
    color:#e2e8f0;padding:8px 10px 8px 32px;border-radius:9px;font-size:13px;
  }
  .tbl-search::placeholder{color:#475569}
  .tbl-search-wrap .si{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#475569}
  .search-hint{font-size:10.5px;color:var(--sidebar-dim);margin:2px 2px 0;font-family:var(--mono)}

  .tbl-list{list-style:none;margin:6px 0 0;padding:0 6px 14px;overflow:auto;flex:1}
  .tbl-list li{
    display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;cursor:pointer;
    color:var(--sidebar-text);font-size:13px;
  }
  .tbl-list li:hover{background:var(--sidebar-bg-2)}
  .tbl-list li.active{background:rgba(8,145,178,.18);color:#fff;font-weight:500}
  .tbl-list li .tic{color:#64748b}
  .tbl-list li.active .tic{color:#7dd3fc}
  .tbl-list li .big{margin-left:auto;font-size:9.5px;font-family:var(--mono);color:#fbbf24;background:rgba(180,83,9,.18);padding:1px 5px;border-radius:4px}
  .side-note{padding:10px 16px;border-top:1px solid var(--sidebar-line);color:var(--sidebar-dim);font-size:11px;display:flex;gap:7px}
  .side-note svg{flex:none;margin-top:1px}

  /* ---------- main ---------- */
  .main{overflow:auto;padding:0}
  .crumb{display:flex;align-items:center;gap:8px;padding:14px 24px 0;color:var(--ink-3);font-size:12.5px;font-family:var(--mono)}
  .crumb .cur{color:var(--ink);font-weight:600}
  .crumb svg{color:#cbd5e1}

  /* tabs */
  .tabs{display:flex;gap:2px;padding:10px 24px 0;border-bottom:1px solid var(--line);margin:8px 0 0}
  .tab{
    appearance:none;border:0;background:transparent;cursor:pointer;
    padding:10px 16px;font-size:13px;font-weight:500;color:var(--ink-3);
    border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px;transition:color .15s;
  }
  .tab:hover{color:var(--ink-2)}
  .tab.active{color:var(--indigo);border-bottom-color:var(--indigo)}
  .tab .cnt{font-family:var(--mono);font-size:11px;color:var(--ink-3);background:var(--line-2);padding:0 6px;border-radius:5px}

  .content{padding:20px 24px 40px}
  .panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
  .panel-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line-2)}
  .panel-head h3{margin:0;font-size:13.5px;font-weight:600;letter-spacing:-.01em}
  .panel-head .mono{font-family:var(--mono);color:var(--cyan)}
  .panel-head .right{margin-left:auto;display:flex;align-items:center;gap:8px}

  /* grid table */
  .gridwrap{overflow:auto;max-height:60vh}
  table.grid{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}
  table.grid th,table.grid td{padding:8px 14px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--line-2)}
  table.grid thead th{
    position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--ink-2);
    font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;
    border-bottom:1px solid var(--line);
  }
  table.grid thead th .colflag{margin-left:6px}
  table.grid tbody tr:nth-child(even){background:var(--zebra)}
  table.grid tbody tr:hover{background:#eef4ff}
  table.grid td.mono,table.grid th.mono{font-family:var(--mono);font-size:12.5px}
  .cell-id{font-family:var(--mono);color:var(--indigo);font-weight:500}
  .cell-mask{font-family:var(--mono);color:var(--ink-3)}
  .pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;font-family:var(--mono)}
  .pill-open{background:var(--emerald-soft);color:var(--emerald)}
  .pill-closed{background:#f1f5f9;color:#475569}
  .pill-pending{background:var(--amber-soft);color:var(--amber)}
  .pill-void{background:var(--rose-soft);color:var(--rose)}

  /* column flags (struktur) */
  .flag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;font-family:var(--mono)}
  .flag-vis{background:var(--emerald-soft);color:var(--emerald)}
  .flag-mask{background:var(--amber-soft);color:var(--amber)}
  .flag-block{background:var(--rose-soft);color:var(--rose)}
  .keytag{font-family:var(--mono);font-size:10.5px;font-weight:600;padding:1px 6px;border-radius:5px;background:var(--indigo-soft);color:var(--indigo)}
  .keytag.uni{background:var(--cyan-soft);color:var(--cyan)}
  .keytag.mul{background:#f1f5f9;color:#475569}

  /* filter toolbar */
  .toolbar{background:#fbfdff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);margin-bottom:16px}
  .toolbar-top{display:flex;align-items:center;gap:9px;margin-bottom:12px}
  .toolbar-top h4{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600}
  .toolbar-top .and{font-family:var(--mono);font-size:10.5px;color:var(--indigo);background:var(--indigo-soft);padding:1px 7px;border-radius:5px}
  .fcond{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
  .fcond .andlabel{width:42px;font-family:var(--mono);font-size:11px;color:var(--ink-3);text-align:right}
  .fcond select,.fcond input{
    border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:13px;background:#fff;color:var(--ink);
  }
  .fcond select{cursor:pointer}
  .fcond .col{min-width:150px}
  .fcond .op{min-width:120px}
  .fcond .val{min-width:170px;flex:1}
  .fcond .xbtn{border:1px solid var(--line);background:#fff;color:var(--ink-3);width:32px;height:32px;border-radius:8px;cursor:pointer;display:grid;place-items:center}
  .fcond .xbtn:hover{color:var(--rose);border-color:#fecdd3}
  .toolbar-actions{display:flex;align-items:center;gap:8px;margin-top:4px}
  .btn{
    appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink-2);
    padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;
    display:inline-flex;align-items:center;gap:7px;transition:.14s;
  }
  .btn:hover{border-color:#cbd5e1;background:#f8fafc}
  .btn-primary{background:var(--indigo);border-color:var(--indigo);color:#fff;box-shadow:0 2px 8px rgba(79,70,229,.28)}
  .btn-primary:hover{background:#4338ca;border-color:#4338ca}
  .btn-ghost{border-color:transparent;background:transparent;color:var(--ink-3)}
  .btn-ghost:hover{background:#f1f5f9}
  .btn-add{border-style:dashed;color:var(--indigo);border-color:#c7d2fe;background:var(--indigo-soft)}
  .btn:disabled{opacity:.5;cursor:not-allowed}
  .btn .ic{display:grid;place-items:center}

  /* meta strip above grid */
  .metastrip{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:11px 16px;border-bottom:1px solid var(--line-2);background:#fcfdff}
  .metastrip .limit{font-size:12.5px;color:var(--ink-2);font-weight:500}
  .metastrip .limit b{color:var(--indigo);font-family:var(--mono)}
  .metastrip .legend{display:flex;align-items:center;gap:12px;font-size:11.5px;color:var(--ink-3)}
  .metastrip .legend span{display:inline-flex;align-items:center;gap:5px}
  .metastrip .ps{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-3)}
  .metastrip .ps select{border:1px solid var(--line);border-radius:7px;padding:4px 8px;font-size:12px}
  .metastrip .right{margin-left:auto;display:flex;align-items:center;gap:10px}

  .replica-note{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--amber);background:var(--amber-soft);border:1px solid #fde68a;padding:3px 9px;border-radius:7px;font-weight:500}

  /* search (Cari) */
  .searchsec{padding:14px 0;border-bottom:1px dashed var(--line)}
  .searchsec:last-of-type{border-bottom:0}
  .searchsec-h{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:9px}
  .searchsec-h .hint{font-size:10.5px;text-transform:none;letter-spacing:0;color:#94a3b8;font-weight:400}
  .searchsec-h .and{font-family:var(--mono);font-size:10px;color:var(--indigo);background:var(--indigo-soft);padding:1px 7px;border-radius:5px;font-weight:600}
  .qgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px 18px}
  .qf{display:flex;flex-direction:column;gap:5px}
  .qf label{font-size:12px;color:var(--ink-2);font-weight:500;display:flex;align-items:center;gap:7px}
  .qf input{border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:13px;font-family:var(--mono)}
  .qf input:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-soft)}
  .qrange{display:flex;align-items:center;gap:7px}
  .qrange input{flex:1;min-width:0}
  .ixb{font-family:var(--mono);font-size:9.5px;font-weight:600;padding:1px 6px;border-radius:5px;background:var(--emerald-soft);color:var(--emerald)}
  .nixb{font-family:var(--mono);font-size:9.5px;font-weight:600;padding:1px 6px;border-radius:5px;background:var(--amber-soft);color:var(--amber)}
  .pfxb{font-family:var(--mono);font-size:9.5px;font-weight:600;padding:1px 6px;border-radius:5px;background:var(--cyan-soft);color:var(--cyan)}
  .qcap{font-size:10.5px;color:#64748b;line-height:1.4}
  .qcap code{font-family:var(--mono);background:#f1f5f9;padding:0 3px;border-radius:3px}
  .perfwarn{display:flex;gap:9px;align-items:flex-start;margin-top:12px;background:var(--amber-soft);border:1px solid #fde68a;border-radius:9px;padding:10px 13px;font-size:12px;color:#92400e}
  .perfwarn svg{flex:none;margin-top:1px;color:var(--amber)}
  .perfwarn code{font-family:var(--mono);background:#fffaf0;padding:0 4px;border-radius:4px}
  .searchactions{display:flex;align-items:center;gap:8px;padding-top:14px}

  /* query preview */
  .qprev{font-family:var(--mono);font-size:12px;color:#475569;background:#0f172a;color:#cbd5e1;padding:11px 14px;border-radius:9px;margin-bottom:14px;display:flex;gap:10px;align-items:flex-start;overflow:auto}
  .qprev .lock{color:#64748b;flex:none;margin-top:1px}
  .qprev .kw{color:#7dd3fc}
  .qprev .tagro{margin-left:auto;flex:none;font-size:10px;color:#64748b;background:#1e293b;padding:1px 7px;border-radius:5px;white-space:nowrap}

  /* pagination */
  .pager{display:flex;align-items:center;gap:6px;padding:12px 16px;border-top:1px solid var(--line-2)}
  .pager .pbtn{border:1px solid var(--line);background:#fff;border-radius:7px;padding:6px 11px;font-size:12.5px;cursor:pointer;color:var(--ink-2);display:inline-flex;gap:6px;align-items:center}
  .pager .pbtn:hover{background:#f8fafc}
  .pager .pinfo{font-size:12px;color:var(--ink-3);font-family:var(--mono)}
  .pager .pno{font-weight:600;color:var(--ink);background:var(--indigo-soft);border-radius:7px;padding:6px 11px;font-family:var(--mono);font-size:12.5px}
  .pager .note{margin-left:auto;font-size:11px;color:var(--ink-3)}

  /* warning banner */
  .warn{display:flex;gap:12px;align-items:flex-start;background:var(--amber-soft);border:1px solid #fde68a;border-radius:var(--radius);padding:14px 16px;margin-bottom:16px}
  .warn .wic{flex:none;color:var(--amber);margin-top:1px}
  .warn h4{margin:0 0 3px;font-size:13px;color:#92400e}
  .warn p{margin:0;font-size:12.5px;color:#92400e}
  .warn .cols{font-family:var(--mono);font-size:12px;color:#b45309;margin-top:4px}
  .warn .wact{margin-top:9px;display:flex;gap:8px}
  .warn .wbtn{border:1px solid #fcd34d;background:#fff;color:#92400e;padding:6px 12px;border-radius:7px;font-size:12px;cursor:pointer;font-weight:500}

  /* empty / error states */
  .state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 24px;color:var(--ink-3)}
  .state .ico{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px}
  .state.empty .ico{background:var(--indigo-soft);color:var(--indigo)}
  .state.error .ico{background:var(--rose-soft);color:var(--rose)}
  .state.timeout .ico{background:var(--amber-soft);color:var(--amber)}
  .state h3{margin:0 0 6px;font-size:15px;color:var(--ink)}
  .state p{margin:0 0 16px;max-width:420px;font-size:13px}

  /* landing */
  .landing{padding:34px 24px}
  .landing h2{margin:0 0 4px;font-size:18px;letter-spacing:-.01em}
  .landing p.lead{margin:0 0 22px;color:var(--ink-3);font-size:13.5px}
  .dbcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;max-width:840px}
  .dbcard{
    text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;cursor:pointer;
    box-shadow:var(--shadow-sm);transition:.16s;display:flex;flex-direction:column;gap:8px;
  }
  .dbcard:hover{border-color:#c7d2fe;box-shadow:var(--shadow);transform:translateY(-2px)}
  .dbcard .top{display:flex;align-items:center;gap:10px}
  .dbcard .ic{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,#eef2ff,#ecfeff);display:grid;place-items:center;color:var(--indigo)}
  .dbcard .nm{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--ink)}
  .dbcard .ds{font-size:12.5px;color:var(--ink-3)}
  .dbcard .meta{font-size:11px;color:var(--ink-3);font-family:var(--mono);display:flex;gap:8px;align-items:center;margin-top:2px}
  .landing .infonote{display:flex;gap:8px;align-items:center;margin-top:22px;color:var(--ink-3);font-size:12.5px}

  /* modal */
  .overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;z-index:50;padding:24px}
  .overlay.show{display:flex;animation:fade .15s ease}
  @keyframes fade{from{opacity:0}to{opacity:1}}
  .modal{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:min(560px,100%);max-height:90vh;overflow:auto;animation:pop .18s cubic-bezier(.2,.9,.3,1.2)}
  @keyframes pop{from{transform:translateY(8px) scale(.97);opacity:0}to{transform:none;opacity:1}}
  .modal-head{display:flex;align-items:center;gap:11px;padding:18px 20px 14px;border-bottom:1px solid var(--line-2)}
  .modal-head .mic{width:34px;height:34px;border-radius:9px;background:var(--emerald-soft);color:var(--emerald);display:grid;place-items:center}
  .modal-head h3{margin:0;font-size:15px}
  .modal-head p{margin:1px 0 0;font-size:11.5px;color:var(--ink-3)}
  .modal-head .x{margin-left:auto;border:0;background:transparent;cursor:pointer;color:var(--ink-3);width:30px;height:30px;border-radius:8px;display:grid;place-items:center}
  .modal-head .x:hover{background:#f1f5f9}
  .modal-body{padding:18px 20px}
  .kv{display:grid;grid-template-columns:108px 1fr;gap:8px 12px;margin-bottom:16px;font-size:13px}
  .kv .k{color:var(--ink-3)}
  .kv .v{color:var(--ink);font-weight:500}
  .kv .v.mono{font-family:var(--mono);font-size:12.5px}
  .rowopts{display:flex;gap:8px;margin-bottom:16px}
  .ropt{flex:1;border:1px solid var(--line);border-radius:9px;padding:10px;text-align:center;cursor:pointer;font-family:var(--mono);font-weight:600;font-size:14px;color:var(--ink-2);transition:.12s}
  .ropt small{display:block;font-family:var(--sans);font-weight:400;font-size:10.5px;color:var(--ink-3);margin-top:2px}
  .ropt:hover{border-color:#c7d2fe}
  .ropt.active{border-color:var(--indigo);background:var(--indigo-soft);color:var(--indigo)}
  .collist{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
  .coltag{font-family:var(--mono);font-size:11.5px;padding:3px 8px;border-radius:6px;background:#f1f5f9;color:var(--ink-2)}
  .coltag.m{background:var(--amber-soft);color:var(--amber)}
  .fieldlbl{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}
  .fieldlbl .req{color:var(--rose)}
  textarea.reason{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-family:inherit;font-size:13px;resize:vertical;min-height:64px}
  textarea.reason:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-soft)}
  .reason-hint{font-size:11px;color:var(--ink-3);margin-top:5px}
  .notice{display:flex;gap:9px;align-items:flex-start;padding:11px 13px;border-radius:9px;font-size:12px;margin-top:14px}
  .notice.warn-n{background:var(--rose-soft);color:#9f1239;border:1px solid #fecdd3}
  .notice.info-n{background:var(--cyan-soft);color:#155e75;border:1px solid #a5f3fc}
  .notice svg{flex:none;margin-top:1px}
  .modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px 20px;border-top:1px solid var(--line-2)}

  /* toast */
  .toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);opacity:0;
    background:#0f172a;color:#e2e8f0;padding:12px 18px;border-radius:11px;box-shadow:var(--shadow-lg);
    display:flex;align-items:center;gap:10px;font-size:13px;z-index:60;transition:.25s;border:1px solid #1e293b}
  .toast.show{opacity:1;transform:translateX(-50%)}
  .toast .ti{color:#34d399}
  .toast code{font-family:var(--mono);color:#7dd3fc;font-size:12px}

  .hidden{display:none!important}
