/* ===========================================================================
   AIOS Light portal - design tokens + styles (Portal P2)

   THE SUPERSEDABLE TOKEN LAYER. Every color, spacing step, radius, and
   type size the UI uses is named here in :root and consumed by var()
   everywhere below. A future frontend-design skill replaces THIS BLOCK
   to restyle the portal without touching markup or logic.

   Aesthetic: dark premium console (Linear/Vercel-class): near-black
   surfaces with one accent, generous whitespace, quiet borders, data
   set in tabular numerals.
   =========================================================================== */

:root {
  /* -- color tokens -------------------------------------------------- */
  --bg:            #09090b;  /* page background */
  --surface:       #101013;  /* cards, sidebar */
  --surface-2:     #18181c;  /* raised elements, inputs, code */
  --border:        #26262c;  /* hairline borders */
  --border-strong: #3a3a42;  /* focused/hovered borders */
  --text:          #f4f4f5;  /* primary text */
  --text-dim:      #a1a1aa;  /* secondary text */
  --text-faint:    #63636b;  /* tertiary, labels, placeholders */
  --accent:        #7c6cf6;  /* the one accent (indigo-violet) */
  --accent-hover:  #8d7ff8;
  --accent-text:   #ffffff;
  --ok:            #34d399;  /* allow / healthy */
  --warn:          #fbbf24;  /* review / pending */
  --danger:        #f87171;  /* deny / error */

  /* -- spacing tokens (4px base scale) -------------------------------- */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;

  /* -- radius tokens --------------------------------------------------- */
  --r-sm: 6px; --r-md: 10px; --r-lg: 14px;

  /* -- type tokens ----------------------------------------------------- */
  --font-ui: ui-sans-serif, -apple-system, "SF Pro Text", "Segoe UI", Inter, Roboto, sans-serif;
  --font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  --fs-xs: 11px; --fs-sm: 13px; --fs-md: 14px; --fs-lg: 16px;
  --fs-xl: 20px; --fs-2xl: 28px;

  /* -- effects ---------------------------------------------------------- */
  --shadow-card: 0 1px 2px rgba(0,0,0,.5), 0 8px 32px rgba(0,0,0,.35);
  --ring: 0 0 0 3px rgba(124,108,246,.25);
}

/* ===========================================================================
   Base
   =========================================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }

/* The hidden attribute must beat author display values: .login-wrap and
   .shell set display:grid, which outranks the UA's [hidden] rule and made
   both views render at once (the P3 bug-1 root cause). */
[hidden] { display: none !important; }

html, body { height: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: var(--fs-md);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

code, .mono { font-family: var(--font-mono); font-size: var(--fs-sm); }

/* ===========================================================================
   Login screen
   =========================================================================== */

.login-wrap {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background:
    radial-gradient(1200px 600px at 70% -10%, rgba(124,108,246,.14), transparent 60%),
    var(--bg);
}

.login-card {
  width: 380px;
  max-width: calc(100vw - var(--sp-6));
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  padding: var(--sp-6);
}

.brand {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}

.brand-mark {
  width: 34px; height: 34px; border-radius: var(--r-sm);
  background: linear-gradient(135deg, var(--accent), #4f46e5);
  display: grid; place-items: center;
  font-weight: 700; font-size: var(--fs-lg); color: var(--accent-text);
}

.brand-name { font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.01em; }
.brand-sub  { font-size: var(--fs-xs); color: var(--text-faint); text-transform: uppercase; letter-spacing: .08em; }

.login-title { font-size: var(--fs-xl); font-weight: 600; margin-bottom: var(--sp-2); letter-spacing: -0.02em; }
.login-sub   { color: var(--text-dim); font-size: var(--fs-sm); margin-bottom: var(--sp-5); }

.field { margin-bottom: var(--sp-4); }
.field label {
  display: block; font-size: var(--fs-xs); color: var(--text-faint);
  text-transform: uppercase; letter-spacing: .07em; margin-bottom: var(--sp-2);
}
.field input {
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: var(--fs-md);
  padding: 10px var(--sp-3);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.field input:focus { border-color: var(--accent); box-shadow: var(--ring); }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  width: 100%;
  border: none; border-radius: var(--r-sm);
  padding: 10px var(--sp-4);
  font-size: var(--fs-md); font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.btn-primary { background: var(--accent); color: var(--accent-text); }
.btn-primary:hover { background: var(--accent-hover); }
.btn-secondary {
  background: var(--surface-2); color: var(--text);
  border: 1px solid var(--border);
}
.btn-secondary:hover { border-color: var(--border-strong); }

.divider {
  display: flex; align-items: center; gap: var(--sp-3);
  color: var(--text-faint); font-size: var(--fs-xs);
  margin: var(--sp-4) 0;
}
.divider::before, .divider::after { content: ""; flex: 1; height: 1px; background: var(--border); }

.login-error {
  color: var(--danger); font-size: var(--fs-sm);
  margin-top: var(--sp-3); min-height: 1.4em;
}

/* ===========================================================================
   App shell
   =========================================================================== */

.shell { display: grid; grid-template-columns: 232px 1fr; min-height: 100vh; }

.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  padding: var(--sp-5) var(--sp-4);
  display: flex; flex-direction: column; gap: var(--sp-5);
}

.nav { display: flex; flex-direction: column; gap: 2px; }

.nav-item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 8px var(--sp-3);
  border-radius: var(--r-sm);
  color: var(--text-dim);
  font-size: var(--fs-md);
  cursor: pointer;
  user-select: none;
}
.nav-item:hover { color: var(--text); background: var(--surface-2); }
.nav-item.active { color: var(--text); background: var(--surface-2); font-weight: 600; }
.nav-item .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--text-faint); }
.nav-item.active .dot { background: var(--accent); }

.sidebar-footer { margin-top: auto; }
.signout {
  color: var(--text-faint); font-size: var(--fs-sm); cursor: pointer;
  padding: var(--sp-2) var(--sp-3);
}
.signout:hover { color: var(--danger); }

.main { padding: var(--sp-6) var(--sp-7); max-width: 1080px; }

.page-head { margin-bottom: var(--sp-6); }
.page-title { font-size: var(--fs-2xl); font-weight: 650; letter-spacing: -0.02em; }
.page-sub   { color: var(--text-dim); font-size: var(--fs-sm); margin-top: var(--sp-1); }

.tenant-chip {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 999px; padding: 4px var(--sp-3);
  font-size: var(--fs-xs); color: var(--text-dim);
}

/* ===========================================================================
   Cards, tables, data
   =========================================================================== */

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  margin-bottom: var(--sp-5);
}

.card-title {
  font-size: var(--fs-xs); color: var(--text-faint);
  text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: var(--sp-4);
}

.kv { display: grid; grid-template-columns: 180px 1fr; row-gap: var(--sp-3); align-items: center; }
.kv dt { color: var(--text-dim); font-size: var(--fs-sm); }
.kv dd { font-family: var(--font-mono); font-size: var(--fs-sm); word-break: break-all; }

.codeblock {
  position: relative;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: var(--text);
  overflow-x: auto;
  white-space: pre;
}

.copy-btn {
  position: absolute; top: var(--sp-2); right: var(--sp-2);
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text-dim);
  font-size: var(--fs-xs); padding: 4px 10px; cursor: pointer;
}
.copy-btn:hover { color: var(--text); border-color: var(--border-strong); }

.chips { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.chip {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 999px; padding: 3px var(--sp-3);
  font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-dim);
}

table.data { width: 100%; border-collapse: collapse; font-variant-numeric: tabular-nums; }
table.data th {
  text-align: left; font-size: var(--fs-xs); color: var(--text-faint);
  text-transform: uppercase; letter-spacing: .07em; font-weight: 600;
  padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--border);
}
table.data td {
  padding: 10px var(--sp-3); border-bottom: 1px solid var(--border);
  font-size: var(--fs-sm); color: var(--text);
}
table.data tr:last-child td { border-bottom: none; }
table.data td.mono { color: var(--text-dim); }

.badge {
  display: inline-block; border-radius: 999px; padding: 2px 10px;
  font-size: var(--fs-xs); font-weight: 600;
}
.badge.allow   { background: rgba(52,211,153,.12); color: var(--ok); }
.badge.deny    { background: rgba(248,113,113,.12); color: var(--danger); }
.badge.review, .badge.pending, .badge.transform { background: rgba(251,191,36,.12); color: var(--warn); }

/* Walkthrough steps (getting started) */

.step {
  display: grid; grid-template-columns: 28px 1fr; gap: var(--sp-4);
  padding: var(--sp-4) 0;
}
.step + .step { border-top: 1px solid var(--border); }
.step-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-2); border: 1px solid var(--border);
  color: var(--accent); font-weight: 700; font-size: var(--fs-sm);
  display: grid; place-items: center;
}
.step-title { font-weight: 600; margin-bottom: var(--sp-2); }
.step-body p { color: var(--text-dim); font-size: var(--fs-sm); margin-bottom: var(--sp-3); }
.step-body p:last-child { margin-bottom: 0; }
.step-body .codeblock { margin-bottom: var(--sp-3); }
.step-body code {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 4px; padding: 1px 5px;
}

.tool-list { display: flex; flex-direction: column; }
.tool {
  display: grid; grid-template-columns: 240px 1fr; gap: var(--sp-4);
  padding: var(--sp-3) 0; align-items: baseline;
}
.tool + .tool { border-top: 1px solid var(--border); }
.tool code { color: var(--accent); }
.tool span { color: var(--text-dim); font-size: var(--fs-sm); }

.empty {
  color: var(--text-faint); font-size: var(--fs-sm);
  padding: var(--sp-6); text-align: center;
}

.loading { color: var(--text-faint); font-size: var(--fs-sm); padding: var(--sp-5); }

.note { color: var(--text-faint); font-size: var(--fs-xs); margin-top: var(--sp-3); }
