/* ============================================================
   zynAuth — Ash · Amethyst admin kit (locked theme)
   paper off-white space · ash neutrals · ~10% amethyst · medium corners

   Vendored from design_handoff_zynauth_admin/design/ash-base.css (+ per-screen
   styles). EVERY rule is scoped under `.ash` so the kit cannot leak onto the
   auth / analytics / survey surfaces that share root.html.heex. Token values are
   the resolved hex from tokens.json (no color-mix()/hsl() → portable + stable).
   ============================================================ */
.ash{
  --bg:#f3f1ea;
  --panel:#f5f3f6;
  --raised:#d6d3da;
  --sidebar:#dcdae0;
  --hover:#d8d6dc;
  --line:#cdc9d1;
  --line-soft:#d9d7dd;
  --muted:#6d6774;
  --faint:#9d97a5;
  --body:#443f4a;
  --ink:#25222b;
  --accent:#9b6ff0;
  --accent-2:#c5abf6;
  --accent-ink:#815dc6;
  --accent-weak:#ece6f5;
  --ok:#1f9d6b; --ok-bg:#e4f2ec;
  --warn:#b4801c; --warn-bg:#f4eddc;
  --danger:#cf4038; --danger-bg:#f7e9e7;
  --bg-grad:radial-gradient(135% 100% at 50% -10%, #f3f1ea 24%, #ddd9e1 100%);
  --sidebar-grad:linear-gradient(180deg, #e6e3ea 0%, #ddd9e1 100%);
  --card-grad:linear-gradient(176deg, #f5f3f6 0%, #e8e5ec 100%);
  /* glass gloss (Apple-style frosted sidebar) — tunable in one place */
  --glass-bg:linear-gradient(180deg, rgba(255,255,255,.40) 0%, rgba(243,238,250,.26) 48%, rgba(228,217,244,.28) 100%);
  --glass-blur:blur(26px) saturate(200%);
  --glass-sheen:linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.14) 26%, rgba(255,255,255,0) 50%);
  --glass-hairline:rgba(255,255,255,.95);
  --glass-lift:8px 0 34px rgba(40,34,52,.13);
  --r:9px; --r-sm:6px;
  --mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  font-family:var(--sans);
  /* ambient color glows give the frosted sidebar something to blur (vibrancy).
     Weighted to the left edge so the sidebar frosts them; content stays clean. */
  background:
    radial-gradient(58% 46% at 4% 10%, rgba(155,111,240,.34), transparent 68%),
    radial-gradient(46% 42% at -4% 82%, rgba(120,150,250,.26), transparent 70%),
    radial-gradient(40% 38% at 100% -4%, rgba(197,171,246,.20), transparent 72%),
    var(--bg-grad);
  background-attachment:fixed;
  color:var(--body);
  font-size:13px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"tnum";
  display:flex;
  height:100vh;
  overflow:hidden;
}
.ash *{box-sizing:border-box;margin:0;padding:0}
.ash .mono{font-family:var(--mono);font-feature-settings:"tnum"}
.ash svg.ic{width:16px;height:16px;stroke-width:1.6}
.ash a{color:inherit;text-decoration:none}

@media (prefers-reduced-motion: reduce){
  .ash *{transition:none !important;animation:none !important}
}

/* ---------- sidebar (glass) ---------- */
.ash .sidebar{width:236px;flex:0 0 236px;border-right:1px solid rgba(255,255,255,.45);
  display:flex;flex-direction:column;padding:14px 11px;position:relative;z-index:2;
  background:var(--glass-bg);
  -webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);
  box-shadow:inset 1.5px 1.5px 0 var(--glass-hairline),inset -1px 0 0 rgba(155,111,240,.12),var(--glass-lift)}
/* top sheen highlight + the gloss streak */
.ash .sidebar::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;
  background:var(--glass-sheen)}
/* sit the chrome above the sheen */
.ash .sidebar > *{position:relative;z-index:1}
.ash .brand{display:flex;align-items:center;gap:10px;padding:6px 9px 12px}
.ash .brand .logo{width:27px;height:27px;border-radius:8px;background:var(--accent);display:grid;place-items:center}
.ash .brand .logo svg{width:15px;height:15px;stroke:#fff}
.ash .brand b{color:var(--ink);font-size:15px;font-weight:650;letter-spacing:-.01em}
.ash .switcher{display:flex;align-items:center;gap:9px;padding:7px 9px;margin-bottom:11px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer}
.ash .switcher .av{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--accent),var(--accent-2));flex:0 0 22px}
.ash .switcher .t{flex:1;min-width:0}.ash .switcher .t .n{color:var(--ink);font-weight:600;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ash .switcher .t .s{color:var(--muted);font-size:11px}.ash .switcher .chev{color:var(--faint)}
.ash .cmd{display:flex;align-items:center;gap:8px;margin-bottom:11px;height:31px;padding:0 10px;border-radius:var(--r-sm);
  background:var(--bg);border:1px solid var(--line);color:var(--faint);font-size:12px;cursor:pointer;width:100%;font-family:inherit}
.ash .cmd svg{width:13px;height:13px;flex:0 0 13px}.ash .cmd .lbltxt{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}
.ash .cmd .k{display:flex;gap:3px}.ash .cmd .k kbd{font-family:var(--mono);font-size:10px;color:var(--muted);background:var(--panel);border-radius:4px;padding:1px 5px;border:1px solid var(--line)}
.ash .navgroup{margin:4px 0}
.ash .navgroup .lbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);padding:9px 9px 5px}
.ash .nav a{display:flex;align-items:center;gap:11px;padding:6.5px 9px;border-radius:7px;color:var(--body);font-weight:500;font-size:12.5px}
.ash .nav a svg{width:15px;height:15px;color:var(--muted);stroke-width:1.7}
.ash .nav a:hover{background:var(--hover)}
.ash .nav a.active{background:var(--accent-weak);color:var(--accent-ink)}
.ash .nav a.active svg{color:var(--accent-ink)}
.ash .nav a .kb{margin-left:auto;font-size:10px;color:var(--faint);font-family:var(--mono)}
.ash .nav a .badge{margin-left:auto;font-size:10.5px;font-weight:600;color:var(--muted);background:var(--hover);border-radius:20px;padding:1px 8px}
.ash .userbtn{margin-top:auto;display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel);cursor:pointer;width:100%;font-family:inherit;text-align:left}
.ash .userbtn .av{width:27px;height:27px;border-radius:50%;background:linear-gradient(135deg,#f472b6,#fb923c);flex:0 0 27px;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:600}
.ash .userbtn .t{flex:1;min-width:0}.ash .userbtn .t .n{color:var(--ink);font-weight:600;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ash .userbtn .t .s{color:var(--muted);font-size:11px}.ash .userbtn svg{color:var(--faint)}
.ash .sidebar.collapsed{width:54px;flex:0 0 54px;padding:14px 7px}
.ash .sidebar.collapsed .brand{justify-content:center;padding:6px 0 12px}
.ash .sidebar.collapsed .switcher,.ash .sidebar.collapsed .cmd,.ash .sidebar.collapsed .navgroup .lbl,
.ash .sidebar.collapsed .nav a span,.ash .sidebar.collapsed .userbtn .t,.ash .sidebar.collapsed .brand b{display:none}
.ash .sidebar.collapsed .nav a{justify-content:center;gap:0}
.ash .sidebar.collapsed .userbtn{justify-content:center}

/* ---------- main / topbar ---------- */
.ash .main{flex:1;display:flex;flex-direction:column;min-width:0}
.ash .topbar{height:55px;flex:0 0 55px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 24px;background:var(--panel)}
.ash .crumb{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}
.ash .crumb a:hover{color:var(--body)}
.ash .crumb b{color:var(--ink);font-weight:600}.ash .crumb svg{width:14px;height:14px;color:var(--faint)}
.ash .search{margin-left:auto;flex:0 0 280px;display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--faint);font-size:12.5px}
.ash .search .k{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--muted);border:1px solid var(--line);border-radius:4px;padding:1px 5px}
.ash .tb-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.ash .pill-env{display:flex;align-items:center;gap:7px;height:32px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--body);font-size:12px;font-weight:550;cursor:pointer}
.ash .pill-env .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px var(--ok-bg)}
.ash .iconbtn{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--bg);display:grid;place-items:center;color:var(--muted);cursor:pointer}
.ash .iconbtn:hover{color:var(--ink);background:var(--hover)}

/* ---------- buttons ---------- */
.ash .btn{display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 13px;border-radius:var(--r-sm);border:1px solid transparent;background:var(--accent);color:#fff;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;text-decoration:none}
.ash .btn svg{width:14px;height:14px}
.ash .btn:hover{background:var(--accent-ink)}
.ash .btn:active{transform:translateY(1px)}
.ash .btn.sec{background:var(--panel);color:var(--body);border-color:var(--line)}
.ash .btn.sec:hover{background:var(--hover)}
.ash .btn.ghost{background:transparent;color:var(--body);border-color:var(--line)}
.ash .btn.ghost:hover{background:var(--hover)}
.ash .btn.danger{background:var(--danger-bg);color:var(--danger);border-color:rgba(207,64,56,.3)}
.ash .btn.danger:hover{background:#f3ddda}
.ash .btn.sm{height:28px;padding:0 10px;font-size:12px}

/* keyboard focus ring — never suppressed (WCAG AA, per brief) */
.ash a:focus-visible,.ash button:focus-visible,.ash input:focus-visible,
.ash select:focus-visible,.ash textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}

/* ---------- content / page head ---------- */
.ash .content{flex:1;overflow:hidden;padding:22px 26px}
.ash .content.scroll{overflow:auto}
.ash .page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:18px}
.ash .page-head h1{color:var(--ink);font-size:23px;font-weight:680;letter-spacing:-.02em}
.ash .page-head p{color:var(--muted);font-size:12.5px;margin-top:3px}
.ash .page-head .actions{margin-left:auto;display:flex;gap:9px}
.ash .range,.ash .tabs{display:flex;background:var(--raised);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px}
.ash .range button,.ash .tabs button{border:none;background:none;font:inherit;font-size:12px;font-weight:550;color:var(--muted);padding:5px 11px;border-radius:5px;cursor:pointer}
.ash .range button.on,.ash .tabs button.on{background:var(--panel);color:var(--accent-ink)}

/* ---------- cards ---------- */
.ash .card{background:var(--card-grad);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ash .card-h{display:flex;align-items:center;gap:10px;padding:14px 17px;border-bottom:1px solid var(--line-soft)}
.ash .card-h h3{color:var(--ink);font-size:13.5px;font-weight:620}
.ash .card-h .sub{color:var(--faint);font-size:11.5px}
.ash .card-h .more{margin-left:auto;color:var(--faint);cursor:pointer}
.ash .card-b{padding:16px 17px}

/* ---------- stat tiles ---------- */
.ash .metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:15px}
.ash .metric{background:var(--card-grad);border:1px solid var(--line);border-radius:var(--r);padding:15px 15px 11px}
.ash .metric .l{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:11.5px;font-weight:550}
.ash .metric .l svg{width:13px;height:13px;color:var(--faint)}
.ash .metric .v{color:var(--ink);font-size:26px;font-weight:700;letter-spacing:-.02em;margin:8px 0 3px;font-family:var(--mono)}
.ash .metric .d{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600}
.ash .metric .d.up{color:var(--ok)}.ash .metric .d.dn{color:var(--danger)}.ash .metric .d svg{width:12px;height:12px}
.ash .metric .spark{margin-top:7px}

/* ---------- tables ---------- */
.ash .tablecard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ash .tc-h{display:flex;align-items:center;gap:12px;padding:13px 17px;border-bottom:1px solid var(--line)}
.ash .tc-h h3{color:var(--ink);font-size:13.5px;font-weight:620}
.ash .tc-h .count{color:var(--muted);font-size:12px;font-family:var(--mono)}
.ash .tc-h .tools{margin-left:auto;display:flex;gap:8px}
.ash .filterpill{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--muted);font-size:12px;font-weight:550;cursor:pointer;font-family:inherit}
.ash .filterpill svg{width:13px;height:13px}
.ash table{width:100%;border-collapse:collapse}
.ash thead th{text-align:left;font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);
  padding:9px 17px;background:var(--raised);border-bottom:1px solid var(--line)}
.ash thead th.num{text-align:right}
.ash tbody td{padding:11px 17px;border-bottom:1px solid var(--line-soft);font-size:12.5px;vertical-align:middle;color:var(--body)}
.ash tbody tr:last-child td{border-bottom:none}
.ash tbody tr:hover{background:var(--hover)}
.ash td.num{text-align:right;font-family:var(--mono);color:var(--body)}
.ash .uid{display:flex;align-items:center;gap:10px}
.ash .uid .av{width:28px;height:28px;border-radius:50%;flex:0 0 28px;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:600}
.ash .uid .e{color:var(--ink);font-weight:550}.ash .uid .e small{display:block;color:var(--muted);font-weight:400;font-size:11px;font-family:var(--mono)}
.ash .rowmenu{color:var(--faint);cursor:pointer;background:none;border:0;padding:0;display:inline-flex}
.ash .pager{display:flex;align-items:center;gap:10px;padding:12px 17px;border-top:1px solid var(--line);color:var(--muted);font-size:12px}
.ash .pager .pg{margin-left:auto;display:flex;gap:6px}
.ash .pager .pg button{width:28px;height:28px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--muted);cursor:pointer;display:grid;place-items:center}
.ash .pager .pg button svg{width:14px;height:14px}

/* ---------- tags / pills ---------- */
.ash .tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;line-height:1.6}
.ash .tag svg{width:11px;height:11px}
.ash .tag.a{background:var(--accent-weak);color:var(--accent-ink)}
.ash .tag.g{background:var(--ok-bg);color:var(--ok)}
.ash .tag.n{background:var(--hover);color:var(--muted)}
.ash .tag.w{background:var(--warn-bg);color:var(--warn)}
.ash .tag.d{background:var(--danger-bg);color:var(--danger)}
.ash .method{display:inline-flex;align-items:center;gap:6px;color:var(--body);font-weight:500}
.ash .method svg{width:14px;height:14px;color:var(--muted)}

/* ---------- detail layout / key-value ---------- */
.ash .detail{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start}
.ash .kv{display:flex;padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:12.5px}
.ash .kv:last-child{border-bottom:none}
.ash .kv .k{flex:0 0 130px;color:var(--muted)}
.ash .kv .v{color:var(--ink);font-weight:500}
.ash .section-lbl{font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}

/* ---------- feed ---------- */
.ash .feed{padding:5px 7px}
.ash .fe{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:7px}
.ash .fe:hover{background:var(--hover)}
.ash .fe .dot{width:8px;height:8px;border-radius:50%;flex:0 0 8px}
.ash .fe .tx{flex:1;min-width:0;font-size:12.5px;color:var(--body)}
.ash .fe .tx b{color:var(--ink);font-weight:600}.ash .fe .tx .mono{color:var(--muted)}
.ash .fe .ts{color:var(--faint);font-size:11px;font-family:var(--mono);white-space:nowrap}

/* ---------- forms ---------- */
.ash .form-row{display:flex;align-items:center;gap:16px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.ash .form-row:last-child{border-bottom:none}
.ash .form-row .lab{flex:0 0 200px}
.ash .form-row .lab .t{color:var(--ink);font-weight:600;font-size:12.5px}
.ash .form-row .lab .h{color:var(--muted);font-size:11.5px;margin-top:2px}
.ash .form-row .ctl{flex:1;display:flex;gap:8px;align-items:center}
.ash .input{height:34px;padding:0 11px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--ink);font:inherit;font-size:12.5px;width:100%}
.ash textarea.input{height:auto;padding:9px 11px;resize:vertical}
.ash select.input{cursor:pointer}
.ash .input.mono{font-family:var(--mono);font-size:12px}
.ash .switch{width:38px;height:22px;border-radius:20px;background:var(--accent);position:relative;cursor:pointer;flex:0 0 38px;border:0;padding:0}
.ash .switch::after{content:"";position:absolute;top:2px;left:18px;width:18px;height:18px;border-radius:50%;background:#fff}
.ash .switch.off{background:var(--raised)}.ash .switch.off::after{left:2px}
.ash .field-lbl{display:block;font-size:11.5px;font-weight:600;color:var(--muted);margin-bottom:5px}

/* ---------- secret reveal + snippet ---------- */
.ash .secret{border:1px solid rgba(180,128,28,.45);background:var(--warn-bg);border-radius:var(--r);padding:14px 16px;margin-bottom:16px}
.ash .secret .sh{display:flex;align-items:center;gap:9px;margin-bottom:11px}
.ash .secret .sh svg{width:15px;height:15px;color:var(--warn)}
.ash .secret .sh b{color:var(--ink);font-size:13px;font-weight:600}
.ash .secret .sh span{color:var(--muted);font-size:12px}
.ash .secret .row{display:flex;gap:8px;flex-wrap:wrap}
.ash .secret .field{flex:1;min-width:240px;display:flex;align-items:center;height:38px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);font-family:var(--mono);font-size:13px;color:var(--ink);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.ash .secret .act{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 13px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--panel);color:var(--ink);font:inherit;font-size:12.5px;font-weight:550;cursor:pointer}
.ash .secret .act svg{width:14px;height:14px}.ash .secret .act.pri{background:var(--accent);border-color:transparent;color:#fff}
.ash .snip{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel)}
.ash .snip .stabs{display:flex;align-items:center;border-bottom:1px solid var(--line);padding:0 6px;background:var(--bg)}
.ash .snip .stabs button{border:none;background:none;font:inherit;font-family:var(--mono);font-size:12px;color:var(--muted);padding:11px 13px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.ash .snip .stabs button.on{color:var(--ink);border-bottom-color:var(--accent)}
.ash .snip .stabs .copy{margin-left:auto;display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-family:var(--sans);font-size:11.5px;cursor:pointer;background:none;border:0}
.ash .snip .stabs .copy svg{width:13px;height:13px}
.ash .snip pre{margin:0;padding:14px 16px;font-family:var(--mono);font-size:12.5px;line-height:1.7;color:var(--body);overflow:auto;white-space:pre}
.ash .snip pre .k{color:var(--accent-ink)}.ash .snip pre .s{color:var(--ok)}.ash .snip pre .c{color:var(--faint)}.ash .snip pre .v{color:var(--ink)}

/* ---------- impersonation banner (overview) ---------- */
.ash .imp{display:flex;align-items:center;gap:12px;background:var(--warn-bg);border-bottom:1px solid rgba(180,128,28,.35);padding:9px 24px;color:var(--ink);font-size:12.5px}
.ash .imp svg{color:var(--warn);width:16px;height:16px}.ash .imp b{font-weight:650}
.ash .imp .stop{margin-left:auto;display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--line);color:var(--ink);font-weight:600;font-size:12px;padding:5px 11px;border-radius:var(--r-sm);cursor:pointer}

/* ---------- overview chart row ---------- */
.ash .grid2{display:grid;grid-template-columns:1.65fr 1fr;gap:13px}
.ash .chart{padding:14px 14px 4px}
.ash .legend{display:flex;gap:16px;padding:0 17px 12px;font-size:11.5px;color:var(--muted)}
.ash .legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:6px;vertical-align:-1px}
.ash .seg{margin-left:auto;display:flex;background:var(--raised);border-radius:6px;padding:2px}
.ash .seg button{border:none;background:none;font:inherit;font-size:11px;color:var(--muted);padding:3px 9px;border-radius:4px;cursor:pointer}
.ash .seg button.on{background:var(--panel);color:var(--ink)}

/* ---------- profile header (user detail) ---------- */
.ash .profile-h{display:flex;align-items:center;gap:15px;margin-bottom:18px}
.ash .profile-h .pa{width:54px;height:54px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:#fff;font-size:20px;font-weight:650;flex:0 0 54px}
.ash .profile-h .pi h1{color:var(--ink);font-size:21px;font-weight:680;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ash .profile-h .pi .em{color:var(--muted);font-size:13px;margin-top:2px;font-family:var(--mono)}
.ash .profile-h .pa-actions{margin-left:auto;display:flex;gap:9px}
.ash .qa{display:flex;flex-direction:column;gap:7px;padding:13px 15px}
.ash .qa button{display:flex;align-items:center;gap:10px;height:36px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--body);font:inherit;font-size:12.5px;font-weight:550;cursor:pointer;text-align:left;width:100%}
.ash .qa button svg{width:15px;height:15px;color:var(--muted)}
.ash .qa button.danger{color:var(--danger);border-color:rgba(207,64,56,.4)}
.ash .qa button.danger svg{color:var(--danger)}
.ash .qa form{margin:0}
.ash .conn{display:flex;align-items:center;gap:11px;padding:11px 15px;border-bottom:1px solid var(--line-soft)}
.ash .conn:last-child{border-bottom:none}
.ash .conn .ci{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--bg);display:grid;place-items:center;color:var(--body)}
.ash .conn .ci svg{width:15px;height:15px}.ash .conn .ct{flex:1}.ash .conn .ct b{color:var(--ink);font-size:12.5px;font-weight:600;display:block}
.ash .conn .ct small{color:var(--muted);font-size:11px;font-family:var(--mono)}

/* ---------- organizations ---------- */
.ash .org{display:flex;align-items:center;gap:11px}
.ash .org .oi{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:650;flex:0 0 30px}
.ash .org .e b{color:var(--ink);font-weight:600;display:block}.ash .org .e small{color:var(--muted);font-family:var(--mono);font-size:11px}
.ash .seats{display:flex;align-items:center;gap:8px}
.ash .seats .bar{width:64px;height:5px;border-radius:3px;background:var(--raised);overflow:hidden}
.ash .seats .bar i{display:block;height:100%;background:var(--accent);border-radius:3px}

/* ---------- team detail ---------- */
.ash .org-h{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.ash .org-h .oa{width:50px;height:50px;border-radius:13px;background:#0ea5e9;display:grid;place-items:center;color:#fff;font-size:18px;font-weight:650;flex:0 0 50px}
.ash .org-h .oi h1{color:var(--ink);font-size:21px;font-weight:680;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.ash .org-h .oi .sl{color:var(--muted);font-size:12.5px;margin-top:2px;font-family:var(--mono)}
.ash .org-h .oa-actions{margin-left:auto;display:flex;gap:9px}
.ash .rolepick{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 9px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--body);font-size:12px;font-weight:550;cursor:pointer;font-family:inherit}
.ash .rolepick svg{width:12px;height:12px;color:var(--faint)}
.ash .roleitem{display:flex;align-items:flex-start;gap:10px;padding:11px 15px;border-bottom:1px solid var(--line-soft)}
.ash .roleitem:last-child{border-bottom:none}
.ash .roleitem .ri{width:30px;height:30px;border-radius:8px;background:var(--accent-weak);color:var(--accent-ink);display:grid;place-items:center;flex:0 0 30px}
.ash .roleitem .ri svg{width:15px;height:15px}
.ash .roleitem .rt b{color:var(--ink);font-size:12.5px;font-weight:600}.ash .roleitem .rt b span{color:var(--muted);font-weight:500;font-family:var(--mono);margin-left:5px}
.ash .roleitem .rt p{color:var(--muted);font-size:11.5px;margin-top:1px}

/* ---------- applications ---------- */
.ash .appname{display:flex;align-items:center;gap:10px}
.ash .appname .aio{width:28px;height:28px;border-radius:7px;border:1px solid var(--line);background:var(--bg);display:grid;place-items:center;color:var(--muted);flex:0 0 28px}
.ash .appname .aio svg{width:14px;height:14px}
.ash .appname .t b{color:var(--ink);font-weight:600;display:block}.ash .appname .t code{color:var(--muted);font-family:var(--mono);font-size:11px}
.ash .uris{display:flex;flex-wrap:wrap;gap:6px}
.ash .uri{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;color:var(--body);background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px 8px}
.ash .uri svg{width:11px;height:11px;color:var(--faint);cursor:pointer}
.ash .agent{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:5px;background:var(--accent-weak);color:var(--accent-ink);font-family:var(--mono)}

/* ---------- audit log ---------- */
.ash .filters{display:flex;align-items:center;gap:9px;margin-bottom:16px;flex-wrap:wrap}
.ash .actor{display:flex;align-items:center;gap:8px}
.ash .actor .a{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:10px;font-weight:600;flex:0 0 24px}
.ash .actor .n{color:var(--ink);font-weight:550}
.ash .act-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:6px;font-family:var(--mono)}
.ash .act-chip svg{width:12px;height:12px}
.ash .act-chip.ok{background:var(--ok-bg);color:var(--ok)}
.ash .act-chip.ac{background:var(--accent-weak);color:var(--accent-ink)}
.ash .act-chip.wn{background:var(--warn-bg);color:var(--warn)}
.ash .act-chip.dn{background:var(--danger-bg);color:var(--danger)}
.ash .act-chip.nt{background:var(--hover);color:var(--muted)}
.ash .tgt{font-family:var(--mono);font-size:11.5px;color:var(--body)}
.ash .loadmore{display:flex;justify-content:center;padding:13px;border-top:1px solid var(--line)}
.ash .loadmore button{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);color:var(--body);font:inherit;font-size:12px;font-weight:550;cursor:pointer}
.ash .loadmore button svg{width:13px;height:13px}

/* expandable audit metadata row */
.ash tr.audit-row{cursor:pointer}
.ash .audit-meta{font-family:var(--mono);font-size:11px;color:var(--muted)}
.ash .audit-meta-pre{margin:0;font-family:var(--mono);font-size:11.5px;line-height:1.6;color:var(--body);white-space:pre-wrap;word-break:break-all;background:var(--bg);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:11px 13px}

/* misc helpers */
.ash .flash-ok{background:var(--ok-bg);color:var(--ok);border:1px solid rgba(31,157,107,.3);border-radius:var(--r-sm);padding:10px 14px;font-size:12.5px;font-weight:550;margin-bottom:14px}
.ash .flash-err{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(207,64,56,.3);border-radius:var(--r-sm);padding:10px 14px;font-size:12.5px;font-weight:550;margin-bottom:14px}
.ash .empty{color:var(--faint);font-size:12.5px;padding:22px 17px;text-align:center}
.ash .col{display:flex;flex-direction:column;gap:16px}
.ash .danger-h h3{color:var(--danger)}

/* ============================================================
   Tenant sidebar collapse (CSS checkbox — no JS/build needed)
   Mirrors `.sidebar.collapsed` (admin's server-driven class) via :has().
   ============================================================ */
.ash .sb-cb{position:absolute;width:0;height:0;opacity:0;pointer-events:none}
.ash .sb-toggle{margin-top:10px;display:flex;align-items:center;justify-content:center;height:30px;
  border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer}
.ash .sb-toggle:hover{background:var(--hover);color:var(--body)}
.ash .sb-toggle svg{width:15px;height:15px}
.ash .sb-toggle .ic-narrow{display:none}
.ash:has(.sb-cb:checked) .sidebar{width:54px;flex:0 0 54px;padding:14px 7px}
.ash:has(.sb-cb:checked) .sidebar .brand{justify-content:center;padding:6px 0 12px}
.ash:has(.sb-cb:checked) .sidebar .brand b,
.ash:has(.sb-cb:checked) .sidebar .navgroup .lbl,
.ash:has(.sb-cb:checked) .sidebar .nav a span,
.ash:has(.sb-cb:checked) .sidebar .userbtn .t,
.ash:has(.sb-cb:checked) .sidebar .userbtn [data-test="tenant-nav-signout"]{display:none}
.ash:has(.sb-cb:checked) .sidebar .nav a{justify-content:center;gap:0}
.ash:has(.sb-cb:checked) .sidebar .userbtn{justify-content:center;padding:8px 0}
.ash:has(.sb-cb:checked) .sb-toggle .ic-wide{display:none}
.ash:has(.sb-cb:checked) .sb-toggle .ic-narrow{display:flex}

/* ---------- signed-out auth column (sign-in / up / MFA / reset) ---------- */
.ash .authwrap{display:flex;justify-content:center;align-items:flex-start}
.ash .authcol{width:100%;max-width:440px;padding:6vh 4px 5vh}
