/*!***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.tsx","import":"Inter","arguments":[{"subsets":["latin"],"variable":"--font-inter","display":"swap"}],"variableName":"inter"} ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/ba9851c3c22cd980-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/21350d82a1f187e9-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/df0a9ae256c0569c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/8e9860b6e62d6359-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Inter Fallback';src: local("Arial");ascent-override: 90.44%;descent-override: 22.52%;line-gap-override: 0.00%;size-adjust: 107.12%
}.__className_f367f3 {font-family: 'Inter', 'Inter Fallback';font-style: normal
}.__variable_f367f3 {--font-inter: 'Inter', 'Inter Fallback'
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.tsx","import":"JetBrains_Mono","arguments":[{"subsets":["latin"],"variable":"--font-jetbrains","display":"swap"}],"variableName":"jetbrains"} ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/886030b0b59bc5a7-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/0aa834ed78bf6d07-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/67957d42bae0796d-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/f911b923c6adde36-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/939c4f875ee75fbb-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/bb3ef058b751a6ad-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'JetBrains Mono Fallback';src: local("Arial");ascent-override: 75.79%;descent-override: 22.29%;line-gap-override: 0.00%;size-adjust: 134.59%
}.__className_3c557b {font-family: 'JetBrains Mono', 'JetBrains Mono Fallback';font-style: normal
}.__variable_3c557b {--font-jetbrains: 'JetBrains Mono', 'JetBrains Mono Fallback'
}

/*!*****************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./src/app/globals.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************/
/* ─── Design tokens ───────────────────────────────────────────── */
:root {
  color-scheme: dark;

  /* surfaces */
  --bg:           #0a0b0d;
  --surface:      #101216;
  --surface-2:    #14171c;
  --surface-3:    #181c22;
  --border:       #23272e;
  --border-soft:  #1c1f25;

  /* text */
  --text:         #e7e9ec;
  --text-muted:   #8b9199;
  --text-dim:     #5b6169;

  /* brand + status */
  --brand:        #22c55e;
  --brand-strong: #16a34a;
  --good:         #34d399;
  --warn:         #f59e0b;
  --bad:          #ef4444;
  --info:         #60a5fa;

  /* radii / shadow */
  --r-sm: 6px;
  --r:    10px;
  --r-lg: 14px;
  --shadow: 0 1px 0 rgba(255,255,255,0.02), 0 8px 24px rgba(0,0,0,0.35);

  /* typography */
  --font-sans: var(--font-inter), -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, sans-serif;
  --font-mono: var(--font-jetbrains), ui-monospace, SFMono-Regular, "SF Mono", Menlo,
               Consolas, "Liberation Mono", monospace;
}

@media (prefers-color-scheme: light) {
  :root {
    color-scheme: light;
    --bg:           #f6f7f9;
    --surface:      #ffffff;
    --surface-2:    #fafbfc;
    --surface-3:    #f1f3f5;
    --border:       #e5e7eb;
    --border-soft:  #eef0f3;
    --text:         #0f172a;
    --text-muted:   #475569;
    --text-dim:     #94a3b8;
    --shadow: 0 1px 0 rgba(15,23,42,0.04), 0 8px 24px rgba(15,23,42,0.06);
  }
}

/* ─── Reset ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-weight: 600; letter-spacing: -0.01em; margin: 0; }
h1 { font-size: 24px; }
h2 { font-size: 18px; }
h3 { font-size: 15px; }
p  { margin: 0; }
a  { color: var(--text); text-decoration: none; }
a:hover { color: var(--brand); }
code, pre, .mono, .num { font-family: var(--font-mono); }

/* ─── Layout primitives ───────────────────────────────────────── */
.shell      { min-height: 100vh; display: flex; flex-direction: column; background: var(--bg); }
.topbar     {
  position: -webkit-sticky;
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; gap: 24px;
  padding: 0 24px; height: 56px;
  background: color-mix(in srgb, var(--surface) 80%, transparent);
  backdrop-filter: saturate(180%) blur(8px);
  -webkit-backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--border);
}
.brand      { display: flex; align-items: center; gap: 8px; font-weight: 700; letter-spacing: -0.02em; }
.brand-dot  { width: 8px; height: 8px; border-radius: 2px; background: var(--brand); box-shadow: 0 0 12px var(--brand); }
.nav        { display: flex; gap: 4px; }
.nav a      {
  padding: 6px 12px; border-radius: var(--r-sm); color: var(--text-muted);
  font-size: 13px; font-weight: 500;
}
.nav a:hover{ color: var(--text); background: var(--surface-3); }
.nav a.active { color: var(--text); background: var(--surface-3); }
.spacer     { flex: 1 1; }
.user-chip  {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 4px 4px 12px; border: 1px solid var(--border); border-radius: 999px;
  color: var(--text-muted); font-size: 13px;
  background: transparent; cursor: pointer; font-family: inherit;
}
.user-chip:hover { background: var(--surface-3); color: var(--text); }
.avatar     {
  width: 28px; height: 28px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-3); color: var(--text); font-weight: 600; font-size: 12px;
}
.user-menu  { position: relative; }
.user-menu-dropdown {
  position: absolute; top: calc(100% + 6px); right: 0; min-width: 200px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm);
  box-shadow: var(--shadow); padding: 6px; z-index: 50;
}
.user-menu-info {
  padding: 8px 10px 10px; border-bottom: 1px solid var(--border-soft); margin-bottom: 6px;
}
.user-menu-name  { color: var(--text); font-size: 13px; font-weight: 600; word-break: break-all; }
.user-menu-email { color: var(--text-muted); font-size: 12px; margin-top: 2px; word-break: break-all; }
.user-menu-item {
  display: block; width: 100%; text-align: left;
  padding: 8px 10px; border-radius: var(--r-sm);
  background: transparent; border: none; cursor: pointer;
  color: var(--text); font-size: 13px; font-family: inherit;
}
.user-menu-item:hover { background: var(--surface-3); }

.main       { padding: 32px 32px 64px; max-width: 1320px; width: 100%; margin: 0 auto; }
.page-head  { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 24px; }
.page-head h1 { font-size: 28px; }
.subtle     { color: var(--text-muted); font-size: 13px; }
.dim        { color: var(--text-dim); }

/* ─── Card ───────────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
}
.card-pad   { padding: 20px; }
.card-head  {
  padding: 14px 20px; border-bottom: 1px solid var(--border-soft);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.card-head h2 { font-size: 14px; font-weight: 600; color: var(--text); }
.card-body  { padding: 20px; }
.card-foot  { padding: 12px 20px; border-top: 1px solid var(--border-soft); color: var(--text-muted); font-size: 12px; }
.grid       { display: grid; grid-gap: 16px; gap: 16px; }
.grid-2     { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid-3     { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.grid-4     { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.row        { display: flex; align-items: center; gap: 12px; }
.col        { display: flex; flex-direction: column; gap: 12px; }

/* ─── Stat tile ──────────────────────────────────────────────── */
.stat       { padding: 16px 18px; }
.stat-label { color: var(--text-muted); font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; }
.stat-value { margin-top: 6px; font-size: 24px; font-weight: 600; font-family: var(--font-mono); }
.stat-sub   { margin-top: 4px; font-size: 12px; color: var(--text-muted); }

/* ─── Button ─────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 14px; border-radius: var(--r-sm);
  font-size: 13px; font-weight: 500; line-height: 1;
  border: 1px solid var(--border); background: var(--surface-2); color: var(--text);
  cursor: pointer; transition: background 120ms, border-color 120ms, color 120ms;
  font-family: inherit;
}
.btn:hover  { background: var(--surface-3); border-color: color-mix(in srgb, var(--border) 60%, var(--text-muted)); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary {
  background: var(--brand); border-color: var(--brand-strong); color: #06120a;
}
.btn-primary:hover { background: var(--brand-strong); border-color: var(--brand-strong); color: #06120a; }
.btn-ghost  { background: transparent; }
.btn-danger { color: var(--bad); border-color: color-mix(in srgb, var(--bad) 30%, var(--border)); }
.btn-danger:hover { background: color-mix(in srgb, var(--bad) 12%, transparent); }
.btn-sm     { padding: 5px 10px; font-size: 12px; }

/* ─── Badge ──────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase;
  background: var(--surface-3); color: var(--text-muted);
  border: 1px solid var(--border);
}
.badge-good { color: var(--good); background: color-mix(in srgb, var(--good) 12%, transparent); border-color: color-mix(in srgb, var(--good) 30%, transparent); }
.badge-warn { color: var(--warn); background: color-mix(in srgb, var(--warn) 12%, transparent); border-color: color-mix(in srgb, var(--warn) 30%, transparent); }
.badge-bad  { color: var(--bad);  background: color-mix(in srgb, var(--bad) 12%, transparent);  border-color: color-mix(in srgb, var(--bad) 30%, transparent); }
.badge-info { color: var(--info); background: color-mix(in srgb, var(--info) 12%, transparent); border-color: color-mix(in srgb, var(--info) 30%, transparent); }

/* ─── Table ──────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table.data {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 13px;
}
table.data thead th {
  position: -webkit-sticky;
  position: sticky; top: 0;
  text-align: left; padding: 10px 14px;
  color: var(--text-muted); font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.06em;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
table.data tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: middle;
}
table.data tbody tr:hover td { background: var(--surface-2); }
table.data tbody tr:last-child td { border-bottom: none; }
.t-right    { text-align: right; }
.t-num      { font-family: var(--font-mono); font-feature-settings: "tnum"; font-variant-numeric: tabular-nums; }

/* ─── Inputs ────────────────────────────────────────────────── */
.input, .select, textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: 13px; font-family: inherit;
  transition: border-color 120ms, background 120ms;
}
.input:focus, .select:focus, textarea:focus {
  outline: none; border-color: var(--brand);
  background: var(--surface);
}
.label { display: block; font-size: 12px; color: var(--text-muted); margin-bottom: 6px; font-weight: 500; }
.check { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; -webkit-user-select: none; -moz-user-select: none; user-select: none; font-size: 13px; }
.check input { accent-color: var(--brand); }

/* ─── Misc ──────────────────────────────────────────────────── */
.divider    { height: 1px; background: var(--border-soft); margin: 16px 0; }
.kv         { display: grid; grid-template-columns: 140px 1fr; grid-row-gap: 8px; row-gap: 8px; grid-column-gap: 16px; column-gap: 16px; font-size: 13px; }
.kv dt      { color: var(--text-muted); }
.kv dd      { margin: 0; font-family: var(--font-mono); }
.empty      {
  padding: 32px; text-align: center; color: var(--text-muted); font-size: 13px;
  border: 1px dashed var(--border); border-radius: var(--r);
}
.tag        {
  display: inline-block; padding: 1px 8px; border-radius: 4px;
  background: var(--surface-3); color: var(--text-muted);
  font-size: 11px; font-family: var(--font-mono);
}
.delta-up   { color: var(--good); }
.delta-down { color: var(--bad); }

/* spinner */
@keyframes spin { to { transform: rotate(360deg); } }
.spinner {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid var(--border); border-top-color: var(--brand);
  animation: spin 0.7s linear infinite; display: inline-block; vertical-align: middle;
}

/* scrollbar */
::-webkit-scrollbar { height: 10px; width: 10px; }
::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: var(--border); }


