/* identity.css — Shared stylesheet for Identity & Access Admin live screens (hex design language) */
/* Moved from marketing/identity_admin_mockup/identity_demo.css by FE-0. */
/* Depends: Google Fonts (Inter + JetBrains Mono) via <link>; no other external deps. */
/* Accent: violet --purple:#8b5cf6 (security/identity track) in place of cash teal. */
/* Tokens copied from core_platform/shared/css/hex-design-system.css + demo.css patterns. */

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
:root {
  /* Core palette (from hex-design-system.css) */
  --dark-bg:#0f172a; --panel-bg:rgba(17,24,39,0.7); --panel-solid:#111827; --card:#0b1220;
  --hex-blue:#3b82f6; --teal:#14b8a6; --cyan:#06b6d4; --amber:#f59e0b; --green:#10b981;
  --red:#ef4444; --purple:#8b5cf6; --pink:#ec4899;
  --text:#f3f4f6; --muted:#94a3b8; --dim:#64748b; --border:rgba(255,255,255,0.08);
  --ui:'Inter',-apple-system,sans-serif; --mono:'JetBrains Mono','Menlo',monospace;
  /* Identity track accent */
  --accent:var(--purple); --accent-rgb:139,92,246;
  --accent-glow:rgba(139,92,246,0.35); --accent-border:rgba(139,92,246,0.5);
  --accent-bg:rgba(139,92,246,0.12); --accent-bg-hover:rgba(139,92,246,0.2);
}
html,body { height:100%; font-family:var(--ui); background:var(--dark-bg); color:var(--muted);
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 50% 0%, rgba(139,92,246,0.07), transparent 55%),
    linear-gradient(rgba(255,255,255,0.013) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.013) 1px, transparent 1px);
  background-size:100% 100%, 40px 40px, 40px 40px; background-attachment:fixed; }
a { text-decoration:none; color:inherit; }

/* ── Command bar ── */
.bar { position:sticky; top:0; z-index:20; display:flex; align-items:center; justify-content:space-between;
  padding:14px 28px; background:rgba(15,23,42,0.85); backdrop-filter:blur(12px) saturate(160%);
  border-bottom:1px solid var(--border); gap:12px; }
.bar .brand { display:flex; align-items:center; gap:12px; min-width:0; }
.bar .logo { font-family:var(--mono); font-weight:800; letter-spacing:0.18em; color:var(--accent);
  border:1px solid var(--accent-border); padding:5px 12px; font-size:0.8rem; flex-shrink:0;
  clip-path:polygon(8px 0,calc(100% - 8px) 0,100% 50%,calc(100% - 8px) 100%,8px 100%,0 50%); }
.bar .title { font-weight:700; color:var(--text); font-size:1.02rem; }
.bar .sub { font-family:var(--mono); font-size:0.6rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--dim); }
.bar .right { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.back { font-family:var(--mono); font-size:0.7rem; color:var(--muted); padding:6px 12px; border:1px solid var(--border);
  border-radius:2px; transition:all .2s; }
.back:hover { color:var(--accent); border-color:var(--accent-border); }
.demo-tag { font-family:var(--mono); font-size:0.58rem; letter-spacing:0.14em; color:var(--amber);
  border:1px solid rgba(245,158,11,0.4); background:rgba(245,158,11,0.1); padding:4px 10px; border-radius:2px; }

/* Bilingual toggle */
.lang-btn { font-family:var(--mono); font-size:0.66rem; font-weight:700; padding:5px 12px; color:var(--dim);
  border:1px solid var(--border); border-radius:2px; cursor:pointer; transition:all .15s; user-select:none; background:none; }
.lang-btn:hover { color:var(--text); border-color:rgba(139,92,246,0.4); }
.lang-btn.ar { color:var(--accent); border-color:var(--accent-border); background:var(--accent-bg); }

/* ── Filter / toolbar panel ── */
.filter { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px;
  margin:20px 28px; padding:12px 18px; background:var(--panel-bg); border:1px solid var(--border);
  clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px); }
.toggles { display:flex; gap:8px; flex-wrap:wrap; }
.tg { font-family:var(--mono); font-size:0.66rem; font-weight:700; padding:7px 16px; color:var(--dim);
  border:1px solid var(--border); border-radius:2px; cursor:pointer; transition:all .15s; user-select:none; }
.tg:hover { color:var(--text); }
.tg.on { color:var(--accent); border-color:var(--accent-border); background:var(--accent-bg);
  box-shadow:0 0 16px rgba(139,92,246,0.15); }

/* Search box */
.search-wrap { display:flex; align-items:center; gap:8px; }
.search-box { background:rgba(17,24,39,0.8); border:1px solid var(--border); color:var(--text);
  font-family:var(--mono); font-size:0.72rem; padding:7px 12px; border-radius:2px; width:220px;
  outline:none; transition:border .2s; }
.search-box:focus { border-color:var(--accent-border); }
.search-box::placeholder { color:var(--dim); }

/* ── Layout ── */
.wrap { padding:0 28px 60px; }
.section-h { font-family:var(--mono); font-size:0.62rem; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--dim); margin:24px 0 12px; }

/* ── KPI cards ── */
.kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; }
.kpi { background:var(--panel-bg); border:1px solid var(--border); padding:18px 20px;
  clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px); }
.kpi .t { font-family:var(--mono); font-size:0.58rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--dim); }
.kpi .v { font-family:var(--mono); font-weight:800; font-size:2rem; color:var(--accent); line-height:1.4; }
.kpi .v.amber { color:var(--amber); }
.kpi .v.red { color:#fca5a5; }
.kpi .v.green { color:var(--green); }
.kpi .v.teal { color:var(--teal); }
.kpi .s { font-size:0.7rem; color:var(--muted); }

/* ── Panels ── */
.grid { display:grid; gap:20px; }
.two { grid-template-columns:1fr 1.3fr; }
@media(max-width:900px){ .two { grid-template-columns:1fr; } }
.panel { background:var(--panel-bg); border:1px solid var(--border); padding:20px 22px;
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px); }
.panel-h { font-weight:700; color:var(--text); font-size:0.92rem; margin-bottom:4px; }
.panel-s { font-size:0.72rem; color:var(--dim); margin-bottom:16px; }

/* ── Donut (conic-gradient) ── */
.donut-wrap { display:flex; align-items:center; gap:24px; }
.donut { width:150px; height:150px; border-radius:50%; flex-shrink:0; position:relative; }
.donut::after { content:''; position:absolute; inset:24px; border-radius:50%; background:var(--panel-solid);
  display:flex; align-items:center; justify-content:center; }
.donut-label { position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  z-index:1; flex-direction:column; pointer-events:none; }
.donut-label .pct { font-family:var(--mono); font-weight:800; font-size:1.25rem; color:var(--accent); }
.donut-label .sub { font-family:var(--mono); font-size:0.5rem; color:var(--dim); letter-spacing:0.08em; text-transform:uppercase; }
.legend { display:flex; flex-direction:column; gap:8px; }
.legend .row { display:flex; align-items:center; gap:8px; font-size:0.74rem; color:var(--muted); }
.legend .sw { width:11px; height:11px; border-radius:2px; flex-shrink:0; }

/* ── Sparkline SVG ── */
.sparkline-wrap { margin-top:8px; }
.sparkline-wrap svg { width:100%; height:60px; display:block; overflow:visible; }

/* ── Tables ── */
table.t { width:100%; border-collapse:collapse; font-size:0.76rem; }
table.t th { font-family:var(--mono); font-size:0.58rem; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--dim); text-align:left; padding:9px 12px; border-bottom:1px solid var(--border); }
table.t td { padding:9px 12px; color:var(--muted); border-bottom:1px solid rgba(255,255,255,0.04); }
table.t tr.click { cursor:pointer; transition:background .15s; }
table.t tr.click:hover { background:rgba(139,92,246,0.07); }
table.t td.id { font-family:var(--mono); color:var(--accent); }
table.t td.num { font-family:var(--mono); color:var(--text); text-align:right; }
[dir="rtl"] table.t th { text-align:right; }
[dir="rtl"] table.t td.num { text-align:left; }

/* ── Status pills ── */
.pill { font-family:var(--mono); font-size:0.58rem; font-weight:700; padding:3px 9px; border-radius:10px; white-space:nowrap; display:inline-block; }
.pill.active { background:rgba(16,185,129,0.18); color:#6ee7b7; }
.pill.invited { background:rgba(139,92,246,0.18); color:#c4b5fd; }
.pill.suspended { background:rgba(245,158,11,0.18); color:#fcd34d; }
.pill.locked { background:rgba(239,68,68,0.18); color:#fca5a5; }
.pill.deprovisioned { background:rgba(100,116,139,0.2); color:#cbd5e1; }
.pill.passkey { background:rgba(16,185,129,0.15); color:#6ee7b7; }
.pill.totp { background:rgba(6,182,212,0.15); color:#67e8f9; }
.pill.aal2 { background:rgba(139,92,246,0.18); color:#c4b5fd; }
.pill.aal3 { background:rgba(236,72,153,0.18); color:#f9a8d4; }
.pill.admin { background:rgba(59,130,246,0.18); color:#93c5fd; }
.pill.viewer { background:rgba(100,116,139,0.18); color:#cbd5e1; }
.pill.sa { background:rgba(239,68,68,0.18); color:#fca5a5; }
.pill.risky { background:rgba(239,68,68,0.18); color:#fca5a5; }
.pill.ok { background:rgba(16,185,129,0.15); color:#6ee7b7; }

/* ── Drawer ── */
.drawer-bg { position:fixed; inset:0; background:rgba(0,0,0,0.5); display:none; z-index:40; }
.drawer-bg.open { display:block; }
.drawer { position:fixed; top:0; height:100%; width:380px; background:var(--panel-solid);
  padding:24px; transition:transform .25s; z-index:41; overflow:auto; }
/* LTR: drawer on right */
.drawer { right:0; border-left:1px solid var(--border); transform:translateX(100%); }
.drawer.open { transform:translateX(0); }
/* RTL: drawer on left */
[dir="rtl"] .drawer { right:auto; left:0; border-left:none; border-right:1px solid var(--border);
  transform:translateX(-100%); }
[dir="rtl"] .drawer.open { transform:translateX(0); }
.drawer h3 { color:var(--text); font-size:1rem; margin-bottom:4px; }
.drawer .close { position:absolute; top:18px; cursor:pointer; color:var(--muted); font-size:1.2rem; }
.drawer .close { right:18px; }
[dir="rtl"] .drawer .close { right:auto; left:18px; }
.drawer-row { display:flex; justify-content:space-between; gap:12px; margin-bottom:10px;
  font-size:0.78rem; color:var(--muted); border-bottom:1px solid rgba(255,255,255,0.04); padding-bottom:10px; }
.drawer-row .lbl { color:var(--dim); font-family:var(--mono); font-size:0.64rem; letter-spacing:0.08em; text-transform:uppercase; }
.drawer-row .val { color:var(--text); text-align:right; }
[dir="rtl"] .drawer-row .val { text-align:left; }

/* ── Shortcut / action tiles ── */
.shortcuts { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:12px; margin-top:12px; }
.shortcut { padding:14px 16px; background:rgba(17,24,39,0.6); border:1px solid var(--border); border-radius:2px;
  cursor:pointer; transition:all .18s; }
.shortcut:hover { border-color:var(--accent-border); background:var(--accent-bg); }
.shortcut .sc-n { font-weight:700; color:var(--text); font-size:0.82rem; margin-bottom:2px; }
.shortcut .sc-s { font-size:0.7rem; color:var(--dim); }
.shortcut .sc-badge { font-family:var(--mono); font-weight:800; font-size:1.4rem; color:var(--amber); margin-bottom:6px; }

/* ── Login form ── */
.login-wrap { display:flex; align-items:center; justify-content:center; min-height:calc(100vh - 64px); padding:40px 20px; }
.login-card { background:var(--panel-bg); border:1px solid var(--border); padding:40px 44px; width:100%; max-width:440px;
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px); }
.login-card .lc-title { font-size:1.3rem; font-weight:800; color:var(--text); margin-bottom:4px; }
.login-card .lc-sub { font-size:0.8rem; color:var(--dim); margin-bottom:28px; font-family:var(--mono);
  font-size:0.65rem; letter-spacing:0.1em; text-transform:uppercase; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-family:var(--mono); font-size:0.6rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--dim); margin-bottom:6px; }
.form-group input { width:100%; background:rgba(17,24,39,0.9); border:1px solid var(--border); color:var(--text);
  font-family:var(--mono); font-size:0.8rem; padding:10px 14px; border-radius:2px; outline:none; transition:border .2s; }
.form-group input:focus { border-color:var(--accent-border); }
.btn-primary { width:100%; padding:13px 20px; background:var(--accent); border:none; color:#fff;
  font-family:var(--mono); font-weight:700; font-size:0.85rem; letter-spacing:0.06em; cursor:pointer;
  border-radius:2px; transition:all .2s; display:flex; align-items:center; justify-content:center; gap:8px; }
.btn-primary:hover { background:#7c3aed; box-shadow:0 0 24px rgba(139,92,246,0.4); }
.btn-link { display:block; text-align:center; margin-top:14px; font-family:var(--mono); font-size:0.7rem;
  color:var(--muted); cursor:pointer; transition:color .15s; background:none; border:none; width:100%; }
.btn-link:hover { color:var(--accent); }
.login-divider { text-align:center; margin:16px 0; font-family:var(--mono); font-size:0.6rem; color:var(--dim); }
.aal-badge { display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:0.58rem;
  font-weight:700; color:var(--accent); border:1px solid var(--accent-border); background:var(--accent-bg);
  padding:3px 10px; border-radius:10px; margin-bottom:20px; }
.security-notice { font-family:var(--mono); font-size:0.6rem; color:var(--dim); text-align:center;
  margin-top:20px; padding-top:16px; border-top:1px solid var(--border); line-height:1.5; }

/* ── Note / footer ── */
.note { font-family:var(--mono); font-size:0.62rem; color:var(--dim); text-align:center;
  margin-top:26px; padding:0 20px 30px; line-height:1.5; }

/* ══════════════════════════════════════════════
   RTL MIRRORING  (dir="rtl" on <html>)
   ══════════════════════════════════════════════ */
[dir="rtl"] { direction:rtl; }

/* Command bar: brand flush right, actions flush left */
[dir="rtl"] .bar { flex-direction:row-reverse; }
[dir="rtl"] .bar .brand { flex-direction:row-reverse; }
[dir="rtl"] .bar .right { flex-direction:row-reverse; }

/* Filter panel: reverse order */
[dir="rtl"] .filter { flex-direction:row-reverse; }
[dir="rtl"] .toggles { flex-direction:row-reverse; }

/* KPI values stay mono-LTR (numerals) — override only labels */
[dir="rtl"] .kpi .t { text-align:right; }
[dir="rtl"] .kpi .s { text-align:right; }

/* Section headings */
[dir="rtl"] .section-h { text-align:right; }

/* Panels */
[dir="rtl"] .panel-h,
[dir="rtl"] .panel-s { text-align:right; }

/* Donut legend */
[dir="rtl"] .legend .row { flex-direction:row-reverse; }

/* Login form */
[dir="rtl"] .login-card { direction:rtl; text-align:right; }
[dir="rtl"] .btn-primary { flex-direction:row-reverse; }
[dir="rtl"] .aal-badge { flex-direction:row-reverse; }

/* Shortcut tiles */
[dir="rtl"] .shortcut { text-align:right; }

/* Sparkline heading */
[dir="rtl"] .spark-head { text-align:right; }
