/* N4N One — design tokens reused from mail SaaS for visual continuity. */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
  --font-sans: "Geist", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --ink: #0B0B10; --ink-soft: #1A1A22;
  --paper: #FAFAF7; --paper-2: #F4F4EF;
  --signal-50:#EEF2FF; --signal-100:#E0E7FF; --signal-200:#C7D2FE; --signal-300:#A5B4FC;
  --signal-400:#818CF8; --signal-500:#6366F1; --signal-600:#4F46E5; --signal-700:#4338CA;
  --pulse-100:#ECFCCB; --pulse-300:#BEF264; --pulse-500:#84CC16; --pulse-700:#4D7C0F;
  --zinc-100:#F4F4F5; --zinc-200:#E4E4E7; --zinc-300:#D4D4D8; --zinc-400:#A1A1AA; --zinc-500:#71717A;
  --fg-1:var(--ink); --fg-2:#3F3F46; --fg-3:#71717A; --fg-4:#A1A1AA;
  --bg-1:var(--paper); --bg-2:#FFFFFF; --bg-3:var(--zinc-100); --bg-4:#EAEAEC;
  --border-1:var(--zinc-200); --border-2:var(--zinc-300);
  --success:#16A34A; --success-soft:#DCFCE7; --danger:#DC2626; --danger-soft:#FEE2E2; --warning:#D97706;
  --shadow-sm:0 1px 2px rgba(15,15,25,0.06);
  --shadow-md:0 4px 12px rgba(15,15,25,0.08);
  --shadow-focus:0 0 0 3px rgba(99,102,241,0.25);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; background: var(--bg-1); font-family: var(--font-sans); color: var(--fg-1); }
a { color: var(--signal-700); text-decoration: none; }
a:hover { text-decoration: underline; }

.auth { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; }
.auth .card { width: 400px; max-width: 100%; background: var(--bg-2); border: 1px solid var(--border-1); border-radius: 12px; padding: 24px 22px; box-shadow: var(--shadow-md); }
.auth h1 { font-size: 22px; margin: 0; font-weight: 600; }
.auth .sub { color: var(--fg-3); font-size: 13px; margin: 4px 0 16px; }
.auth label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fg-3); font-weight: 500; display: block; margin-top: 8px; }
.auth input { width: 100%; padding: 9px 11px; margin: 4px 0 8px; border: 1px solid var(--border-2); border-radius: 6px; font-size: 13px; background: white; font-family: inherit; }
.auth input:focus { outline: none; border-color: var(--signal-600); box-shadow: var(--shadow-focus); }
.auth .primary { width: 100%; padding: 10px 12px; background: var(--ink); color: white; border: 0; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; margin-top: 10px; }
.auth .primary:hover { background: var(--ink-soft); }
.auth .err { background: var(--danger-soft); color: #991B1B; font-size: 12px; padding: 8px 10px; border-radius: 6px; margin-bottom: 6px; display: none; }
.auth .alt { margin-top: 16px; text-align: center; font-size: 12px; color: var(--fg-3); }
.auth .brand { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.auth .brand .logo { width: 36px; height: 36px; border-radius: 8px; background: var(--ink); display: flex; align-items: center; justify-content: center; }
.auth .hint { font-size: 11px; color: var(--fg-3); margin: -4px 0 6px; }

/* App layout */
body.app { background: var(--bg-1); }
.topbar { display: flex; align-items: center; justify-content: space-between; padding: 0 22px; height: 52px; background: var(--bg-2); border-bottom: 1px solid var(--border-1); position: sticky; top: 0; z-index: 5; }
.topbar .left { display: flex; align-items: center; gap: 16px; }
.topbar .logo { width: 32px; height: 32px; border-radius: 8px; background: var(--ink); display: flex; align-items: center; justify-content: center; }
.topbar .title { font-size: 14px; font-weight: 600; }
.topbar .kbd { font-family: var(--font-mono); font-size: 10px; padding: 1px 6px; border-radius: 4px; background: var(--bg-3); color: var(--fg-3); margin-left: 4px; }
.topbar .nav-tabs { display: flex; gap: 4px; margin-left: 8px; }
.topbar .nav-tabs a { padding: 6px 10px; border-radius: 5px; color: var(--fg-3); font-size: 13px; }
.topbar .nav-tabs a:hover { background: var(--bg-3); color: var(--fg-1); text-decoration: none; }
.topbar .nav-tabs a.active { background: var(--bg-3); color: var(--fg-1); }
.topbar .right { display: flex; align-items: center; gap: 8px; }
.topbar .user-pill { font-family: var(--font-mono); font-size: 11px; background: var(--bg-3); padding: 4px 10px; border-radius: 999px; color: var(--fg-2); }

.btn { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; padding: 7px 12px; border-radius: 6px; border: 1px solid transparent; cursor: pointer; font-family: inherit; }
.btn.primary { background: var(--ink); color: white; }
.btn.primary:hover { background: var(--ink-soft); }
.btn.secondary { background: white; border-color: var(--border-2); color: var(--fg-1); }
.btn.secondary:hover { background: var(--bg-3); }
.btn.ghost { background: transparent; color: var(--fg-2); }
.btn.ghost:hover { background: var(--bg-3); color: var(--fg-1); }
.btn.sm { padding: 5px 10px; font-size: 12px; }
.btn.danger { background: white; border-color: #FCA5A5; color: #991B1B; }

.shell { max-width: 1180px; margin: 0 auto; padding: 28px 24px; }
.hero { margin-bottom: 24px; }
.hero h1 { font-size: 26px; font-weight: 600; letter-spacing: -0.015em; margin: 0; }
.hero .muted { color: var(--fg-3); font-size: 14px; margin-top: 4px; }

.block { margin-bottom: 28px; }
.block-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
.block-head h2 { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
.block-head .meta { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }

.apps { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.app-card { background: var(--bg-2); border: 1px solid var(--border-1); border-radius: 12px; padding: 16px 18px; display: flex; flex-direction: column; gap: 8px; min-height: 130px; }
.app-card .top { display: flex; align-items: center; gap: 10px; }
.app-card .icon-w { width: 36px; height: 36px; border-radius: 8px; background: var(--ink); color: white; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 14px; }
.app-card .name { font-size: 15px; font-weight: 600; }
.app-card .desc { font-size: 12px; color: var(--fg-3); line-height: 1.45; flex: 1; }
.app-card .foot { display: flex; gap: 6px; }
.app-card .foot .btn { flex: 1; justify-content: center; }

.orgs { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
.orgs-full .org-card { cursor: pointer; }
.org-card { background: var(--bg-2); border: 1px solid var(--border-1); border-radius: 10px; padding: 14px; display: flex; flex-direction: column; gap: 6px; }
.org-card.active { border-color: var(--signal-300); background: var(--signal-50); }
.org-card .name { font-size: 14px; font-weight: 600; }
.org-card .slug { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }
.org-card .meta { font-size: 11px; color: var(--fg-3); }
.org-card .pill { display: inline-block; font-size: 10px; padding: 1px 7px; border-radius: 99px; background: var(--bg-3); color: var(--fg-3); margin-top: 4px; }

.card { background: var(--bg-2); border: 1px solid var(--border-1); border-radius: 10px; padding: 16px; }
.card h3 { font-size: 13px; font-weight: 600; margin: 0 0 8px; }

.member-row { display: grid; grid-template-columns: 1fr auto auto; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--border-1); align-items: center; }
.member-row:last-child { border-bottom: 0; }
.member-row .e { font-size: 13px; }
.member-row .r { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }

.project-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--border-1); align-items: center; }
.project-row:last-child { border-bottom: 0; }
.project-row .n { font-size: 13px; font-weight: 500; }
.project-row .s { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }

.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 22px; }
.stats .s { background: var(--bg-2); border: 1px solid var(--border-1); border-radius: 10px; padding: 14px 16px; }
.stats .s .k { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.07em; }
.stats .s .v { font-size: 22px; font-weight: 600; letter-spacing: -0.01em; font-family: var(--font-mono); margin-top: 2px; }

.table { width: 100%; border-collapse: collapse; font-size: 13px; }
.table th { text-align: left; font-size: 11px; font-weight: 500; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.05em; padding: 9px 10px; border-bottom: 1px solid var(--border-1); }
.table td { padding: 10px; border-bottom: 1px solid var(--border-1); vertical-align: middle; }
.table tr:last-child td { border-bottom: 0; }
.table .mono { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }

.modal-overlay { position: fixed; inset: 0; background: rgba(11,11,16,0.4); display: none; align-items: center; justify-content: center; z-index: 50; padding: 20px; }
.modal-overlay.open { display: flex; }
.modal { background: white; border-radius: 12px; box-shadow: var(--shadow-md); width: 560px; max-width: 100%; padding: 22px; max-height: calc(100vh - 40px); overflow: auto; }
.modal h2 { font-size: 17px; margin: 0 0 14px; font-weight: 600; }
.modal label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--fg-3); font-weight: 500; display: block; margin: 10px 0 4px; }
.modal label.row.inline { text-transform: none; font-size: 13px; letter-spacing: 0; color: var(--fg-1); display: flex; align-items: center; gap: 8px; margin: 12px 0 4px; font-weight: 400; }
.modal input, .modal textarea { width: 100%; padding: 8px 10px; border: 1px solid var(--border-2); border-radius: 6px; font-size: 13px; background: white; font-family: inherit; }
.modal input:focus, .modal textarea:focus { outline: none; border-color: var(--signal-600); box-shadow: var(--shadow-focus); }
.modal .foot { margin-top: 16px; display: flex; gap: 8px; justify-content: flex-end; }
.modal .err { background: var(--danger-soft); color: #991B1B; font-size: 12px; padding: 8px 10px; border-radius: 6px; margin-bottom: 6px; display: none; }
.modal .err.open { display: block; }
.modal .ok  { background: var(--success-soft); color: #166534; font-size: 12px; padding: 8px 10px; border-radius: 6px; margin-bottom: 6px; display: none; word-break: break-all; }
.modal .ok.open { display: block; }

.muted { color: var(--fg-3); font-size: 13px; }
