/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */
@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial}}}
@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:var(--font-mono);--spacing:.25rem;--font-weight-semibold:600;--font-weight-bold:700;--shadow-sm:var(--shadow-sm);--shadow-md:var(--shadow-md);--shadow-lg:var(--shadow-lg);--shadow-xl:var(--shadow-xl);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--font-display:var(--font-display);--font-body:var(--font-body)}}
@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::-moz-placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}
@layer components;
@layer utilities{.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.grid{display:grid}.inline{display:inline}.table{display:table}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-11{height:calc(var(--spacing) * 11)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-11{width:calc(var(--spacing) * 11)}.flex-shrink-0{flex-shrink:0}.place-items-center{place-items:center}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:3.40282e38px}.rounded-md{border-radius:10px}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-border{border-color:var(--border)}.bg-ink{background-color:var(--ink)}.bg-paper{background-color:var(--bg)}.bg-surface{background-color:var(--surface)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-5{padding:calc(var(--spacing) * 5)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-10{padding-block:calc(var(--spacing) * 10)}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-\[17px\]{font-size:17px}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.02em\]{--tw-tracking:-.02em;letter-spacing:-.02em}.text-ink{color:var(--ink)}.text-ink-muted{color:var(--ink-muted)}.text-paper{color:var(--bg)}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.\[orbit\:event-bus\]{orbit:event-bus}.\[orbit\:event\]{orbit:event}.\[orbit\:remote\]{orbit:remote}}
:root{--bg:#f5f3ec;--surface:#fcfaf4;--surface-2:#ece9de;--surface-hover:#e4e0d2;--ink:#0f0f0e;--ink-2:#3d3c37;--ink-muted:#827f72;--border:#dfdbcc;--border-strong:#c8c3b2;--accent:#7fb53e;--accent-2:#6ca230;--accent-ink:#0f0f0e;--accent-soft:#dfeccd;--accent-glow:#7fb53e5c;--success:#2d7a44;--success-soft:#e3eede;--warning:#8a5a00;--warning-soft:#f7e9c9;--danger:#9b2323;--danger-soft:#f2e1e1;--font-display:"Bricolage Grotesque", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--dur:.2s;--dur-slow:.36s;--ease:cubic-bezier(.2, .8, .2, 1);--spring:cubic-bezier(.34, 1.4, .64, 1);--shadow-sm:0 1px 2px #0f0f0e0a, 0 1px 1px #0f0f0e05;--shadow-md:0 4px 16px #0f0f0e0f, 0 1px 3px #0f0f0e0a;--shadow-lg:0 16px 40px #0f0f0e1a, 0 4px 10px #0f0f0e0d;--shadow-xl:0 32px 80px #0f0f0e24, 0 8px 20px #0f0f0e0f}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}
html{scrollbar-gutter:stable;width:100%;height:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 1px 1px,#0f0f0e0b 1px,#0000 0);background-size:22px 22px;width:100%;height:100%;min-height:100vh;font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}
input,select,textarea{font:inherit;color:inherit}
::-moz-selection{background:var(--accent-soft);color:var(--ink)}
::selection{background:var(--accent-soft);color:var(--ink)}
.app-frame{grid-template-columns:260px 1fr;width:100%;min-height:100vh;display:grid}
.sidebar{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;gap:24px;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}
.brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:6px 10px 14px;display:flex}
.brand-mark{border-radius:var(--r-sm);background:var(--ink);width:36px;height:36px;color:var(--bg);font-family:var(--font-display);letter-spacing:-.04em;flex-shrink:0;place-items:center;font-size:15px;font-weight:700;display:grid;position:relative}
.brand-text{font-family:var(--font-display);letter-spacing:-.03em;font-size:16px;font-weight:600;line-height:1}
.brand-text .sub{font-family:var(--font-mono);color:var(--ink-muted);letter-spacing:0;margin-top:3px;font-size:10px;font-weight:400;display:block}
.sidebar nav{flex-direction:column;gap:2px;display:flex}
.nav-label{font-family:var(--font-mono);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;padding:8px 12px 6px;font-size:10px;font-weight:500}
.sidebar nav a{color:var(--ink-2);border-radius:var(--r-sm);transition:all var(--dur) var(--ease);letter-spacing:-.005em;cursor:pointer;align-items:center;gap:11px;padding:9px 12px;font-size:14px;font-weight:500;display:flex;position:relative}
.sidebar nav a:hover{background:var(--surface-2);color:var(--ink)}
.sidebar nav a.active{background:var(--ink);color:var(--bg);font-weight:600}
.sidebar nav a.active:before{content:"";background:var(--accent);width:3px;height:22px;box-shadow:0 0 12px var(--accent-glow);border-radius:0 3px 3px 0;position:absolute;top:50%;left:-14px;transform:translateY(-50%)}
.sidebar nav a svg{stroke-width:1.75px;flex-shrink:0;width:17px;height:17px}
.sidebar nav a.active svg{color:var(--accent)}
.sidebar nav a .tag{font-family:var(--font-mono);background:var(--accent);color:var(--accent-ink);border-radius:4px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:600}
.sidebar nav .nav-sub{border-left:1px solid var(--border);flex-direction:column;gap:2px;margin:2px 0 4px 12px;padding-left:12px;display:flex}
.sidebar nav .nav-sub a{color:var(--ink-muted);gap:10px;padding:7px 10px;font-size:13px;font-weight:500}
.sidebar nav .nav-sub a:hover{color:var(--ink);background:var(--surface-2)}
.sidebar nav .nav-sub a.active{background:var(--surface-2);color:var(--ink);font-weight:600}
.sidebar nav .nav-sub a.active:before{display:none}
.sidebar nav .nav-sub a svg{width:15px;height:15px}
.spacer{flex:1}
.auth-splash{background:var(--bg);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;padding:48px 24px;display:flex}
.auth-splash .brand-mark{border-radius:var(--r-md);background:var(--ink);width:56px;height:56px;color:var(--bg);font-family:var(--font-display);justify-content:center;align-items:center;margin-bottom:8px;font-size:28px;font-weight:700;display:flex}
.auth-splash .auth-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;margin:0;font-size:28px;font-weight:600}
.auth-splash .auth-body{color:var(--ink-muted);max-width:420px;margin:0;font-size:15px;line-height:1.5}
.auth-splash .muted{color:var(--ink-muted);font-size:14px}
.sidebar .user{border-top:1px solid var(--border);cursor:pointer;transition:background var(--dur) var(--ease);border-radius:var(--r-sm);align-items:center;gap:10px;padding:14px 10px 10px;display:flex}
.sidebar .user:hover{background:var(--surface-2)}
.sidebar .user .avatar{background:var(--ink);width:34px;height:34px;color:var(--bg);font-family:var(--font-display);letter-spacing:-.02em;border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid;position:relative}
.sidebar .user .avatar:after{content:"";background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:10px;height:10px;position:absolute;bottom:-1px;right:-1px}
.user-info{flex:1;min-width:0}
.user-name{letter-spacing:-.01em;font-size:13px;font-weight:600}
.user-email{font-family:var(--font-mono);color:var(--ink-muted);text-overflow:ellipsis;white-space:nowrap;font-size:10.5px;overflow:hidden}
.main-area{flex-direction:column;min-width:0;display:flex}
.topbar{border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;padding:14px 40px;display:flex;position:sticky;top:0}
@supports (color:color-mix(in lab, red, red)){.topbar{background:color-mix(in srgb, var(--bg) 82%, transparent)}}
.topbar{-webkit-backdrop-filter:saturate(160%)blur(12px);z-index:10}
.breadcrumb{color:var(--ink-muted);align-items:center;gap:8px;font-size:13px;display:flex}
.breadcrumb .sep{opacity:.4}
.breadcrumb .current{color:var(--ink);letter-spacing:-.01em;font-weight:600}
.topbar-actions{align-items:center;gap:10px;display:flex}
.cmdk{color:var(--ink-muted);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);min-width:280px;transition:all var(--dur) var(--ease);align-items:center;gap:10px;padding:7px 12px 7px 10px;font-size:12.5px;font-weight:500;display:flex}
.cmdk:hover{border-color:var(--border-strong);background:var(--surface-2)}
.cmdk svg{color:var(--ink-muted);stroke-width:2px;flex-shrink:0;width:13px;height:13px}
.cmdk .placeholder{flex:1}
.kbd,.cmdk .kbd{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);color:var(--ink);border-radius:4px;padding:2px 6px;font-size:10.5px;font-weight:500}
.icon-btn{border-radius:var(--r-sm);width:34px;height:34px;color:var(--ink-2);transition:all var(--dur) var(--ease);background:0 0;border:1px solid #0000;place-items:center;display:grid;position:relative}
.icon-btn:hover{background:var(--surface-2);color:var(--ink)}
.icon-btn svg{stroke-width:1.75px;width:18px;height:18px}
.icon-btn .dot{background:var(--accent);border:2px solid var(--bg);width:8px;height:8px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%;position:absolute;top:6px;right:6px}
.avatar-sm{background:var(--ink);width:32px;height:32px;color:var(--bg);font-family:var(--font-display);transition:transform var(--dur) var(--spring);letter-spacing:-.02em;cursor:pointer;border-radius:50%;place-items:center;font-size:12px;font-weight:700;display:grid}
.avatar-sm:hover{transform:scale(1.08)}
.content{flex:1;width:100%;padding:40px 40px 80px}
.page-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:36px;padding-bottom:24px;display:flex}
.page-header h1{font-family:var(--font-display);letter-spacing:-.035em;margin-bottom:8px;font-size:clamp(36px,3.6vw,52px);font-weight:500;line-height:1}
.page-header h1 .mark{color:var(--ink);background:var(--accent);border-radius:6px;padding:0 10px;font-weight:600}
.page-header p{color:var(--ink-muted);font-size:14px}
.page-header .actions{flex-shrink:0;gap:8px;display:flex}
.btn-ghost{border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink-2);transition:all var(--dur) var(--ease);letter-spacing:-.01em;background:0 0;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;display:inline-flex}
.btn-ghost:hover{background:var(--surface);border-color:var(--border-strong);color:var(--ink)}
.btn-primary{background:var(--accent);border-radius:var(--r-sm);color:var(--accent-ink);transition:background var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);letter-spacing:-.015em;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:700;display:inline-flex}
.btn-primary:hover{background:var(--accent-2);box-shadow:0 4px 14px var(--accent-glow);transform:translateY(-1px)}
.btn-danger{border:1px solid var(--danger-soft);border-radius:var(--r-sm);color:var(--danger);transition:all var(--dur) var(--ease);letter-spacing:-.01em;background:0 0;padding:10px 16px;font-size:13px;font-weight:600}
.btn-danger:hover{background:var(--danger-soft);border-color:var(--danger)}
.btn-block{justify-content:center;width:100%}
.kpi-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:44px;display:grid}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);transition:all var(--dur) var(--ease);cursor:pointer;padding:22px;position:relative;overflow:hidden}
.kpi-card:after{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform var(--dur-slow) var(--ease);position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}
.kpi-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.kpi-card:hover:after{transform:scaleX(1)}
.kpi-card.featured{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.kpi-card.featured .kpi-label{color:#fafaf3a6}
.kpi-card.featured .kpi-value{color:var(--bg)}
.kpi-card.featured:after{background:var(--accent);transform:scaleX(1)}
.kpi-label{font-family:var(--font-mono);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;justify-content:space-between;align-items:center;gap:6px;margin-bottom:14px;font-size:10.5px;font-weight:500;display:flex}
.kpi-value{font-family:var(--font-display);letter-spacing:-.035em;font-variant-numeric:tabular-nums;margin-bottom:12px;font-size:34px;font-weight:500;line-height:1}
.kpi-delta{font-family:var(--font-mono);font-variant-numeric:tabular-nums;border-radius:4px;align-items:center;gap:4px;padding:3px 7px;font-size:11.5px;font-weight:600;display:inline-flex}
.kpi-delta svg{stroke-width:3px;width:11px;height:11px}
.kpi-delta.up{color:var(--success);background:var(--success-soft)}
.kpi-delta.down{color:var(--danger);background:var(--danger-soft)}
.kpi-card.featured .kpi-delta.up{color:var(--accent);background:#7fb53e29}
.kpi-card.featured .kpi-delta.down{color:#ff8a8a;background:#ff8a8a1f}
.section-head{justify-content:space-between;align-items:baseline;margin-bottom:20px;display:flex}
.section-head h2{font-family:var(--font-display);letter-spacing:-.025em;align-items:baseline;gap:10px;font-size:24px;font-weight:500;display:flex}
.section-head h2 .count{font-family:var(--font-mono);color:var(--ink-muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:12px;font-weight:500}
.apps-section{margin-bottom:48px}
.apps-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}
.app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);transition:all var(--dur) var(--ease);cursor:pointer;flex-direction:column;gap:14px;min-height:170px;padding:22px;display:flex;position:relative;overflow:hidden}
.app-card:before{content:"";background:var(--accent);transform-origin:0;height:3px;transition:transform var(--dur-slow) var(--ease);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}
.app-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.app-card:hover:before{transform:scaleX(1)}
.app-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}
.app-icon{border-radius:var(--r-sm);background:var(--surface-2);width:42px;height:42px;color:var(--ink);transition:all var(--dur) var(--ease);place-items:center;display:grid}
.app-icon svg{stroke-width:1.75px;width:19px;height:19px}
.app-card:hover .app-icon{background:var(--ink);color:var(--accent);transform:rotate(-4deg)scale(1.05)}
.app-status{font-family:var(--font-mono);color:var(--success);text-transform:uppercase;letter-spacing:.06em;background:var(--success-soft);border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}
.app-status.pending{color:var(--warning);background:var(--warning-soft)}
.app-status.inactive{color:var(--ink-muted);background:var(--surface-2)}
.app-status .dot{background:currentColor;border-radius:50%;width:5px;height:5px}
.app-name{font-family:var(--font-display);letter-spacing:-.025em;font-size:20px;font-weight:600;line-height:1.1}
.app-desc{color:var(--ink-muted);flex:1;font-size:13px;line-height:1.5}
.app-footer{color:var(--ink-muted);border-top:1px dashed var(--border);justify-content:space-between;align-items:center;gap:10px;padding-top:12px;font-size:11px;display:flex}
.app-footer .meta{font-family:var(--font-mono)}
.app-footer .arrow{background:var(--surface-2);width:22px;height:22px;transition:all var(--dur) var(--spring);border-radius:50%;place-items:center;display:grid}
.app-footer .arrow svg{stroke-width:2.5px;width:12px;height:12px}
.app-card:hover .app-footer .arrow{background:var(--accent);transform:translate(3px)rotate(-45deg)}
.filter-chips{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}
.chip{border:1px solid var(--border);background:var(--surface);color:var(--ink-2);transition:all var(--dur) var(--ease);letter-spacing:-.005em;border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:12.5px;font-weight:500;display:inline-flex}
.chip:hover{border-color:var(--border-strong);color:var(--ink)}
.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink);font-weight:600}
.chip .count{font-family:var(--font-mono);opacity:.7;font-size:10px}
.chip.active .count{opacity:.85}
.data-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:32px;overflow:hidden}
.data-card .card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}
.data-card .card-head h3{font-family:var(--font-display);letter-spacing:-.02em;font-size:17px;font-weight:600}
.data-table{border-collapse:collapse;width:100%}
.data-table thead{background:var(--bg);border-bottom:1px solid var(--border)}
.data-table th{text-align:left;font-family:var(--font-mono);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:10px 20px;font-size:10.5px;font-weight:500}
.data-table th.numeric{text-align:right}
.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:14px 20px;font-size:13px}
.data-table td.numeric{text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:500}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr{transition:background var(--dur) var(--ease)}
.data-table tbody tr:hover{background:var(--surface-2)}
.badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;border-radius:4px;align-items:center;gap:5px;padding:3px 8px;font-size:10.5px;font-weight:600;display:inline-flex}
.badge.success{color:var(--success);background:var(--success-soft)}
.badge.warning{color:var(--warning);background:var(--warning-soft)}
.badge.neutral{color:var(--ink-2);background:var(--surface-2)}
.badge.owner{color:var(--ink);background:var(--accent-soft)}
.badge .dot{background:currentColor;border-radius:50%;width:5px;height:5px}
.field{flex-direction:column;gap:6px;display:flex}
.field>label{color:var(--ink-2);letter-spacing:-.005em;font-size:12px;font-weight:600}
.field>input,.field>select,.field>textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink);font-size:13.5px;font-family:var(--font-body);transition:all var(--dur) var(--ease);width:100%;padding:10px 12px}
.field>input:focus,.field>select:focus,.field>textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface);outline:none}
.field .hint{color:var(--ink-muted);font-size:11px;font-family:var(--font-mono)}
.input-base,.select-base{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink);font-size:13.5px;font-family:var(--font-body);transition:all var(--dur) var(--ease);width:100%;padding:10px 12px}
.input-base:focus,.select-base:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface);outline:none}
.toggle{background:var(--surface-2);width:38px;height:22px;transition:background var(--dur) var(--ease);cursor:pointer;border:none;border-radius:999px;flex-shrink:0;position:relative}
.toggle:after{content:"";background:var(--surface);width:18px;height:18px;box-shadow:var(--shadow-sm);transition:transform var(--dur) var(--spring);border-radius:50%;position:absolute;top:2px;left:2px}
.toggle.on{background:var(--accent)}
.toggle.on:after{transform:translate(16px)}
.skeleton{background:linear-gradient(90deg, var(--surface-2) 0%, var(--surface-hover) 50%, var(--surface-2) 100%);border-radius:var(--r-sm);background-size:200% 100%;animation:1.6s linear infinite skeleton-shimmer}
@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
.separator{background:var(--border)}
.separator-horizontal{width:100%;height:1px}
.separator-vertical{width:1px;height:100%}
@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.page>*,.layout-login .login-card{animation:fadeInUp .46s var(--ease) backwards}
.page>:first-child{animation-delay:40ms}
.page>:nth-child(2){animation-delay:90ms}
.page>:nth-child(3){animation-delay:.14s}
.page>:nth-child(4){animation-delay:.19s}
.page>:nth-child(5){animation-delay:.24s}
@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
@media (max-width:900px){.app-frame{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border);height:auto;position:static}.spacer{display:none}.kpi-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}}
@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
@property --tw-font-weight{syntax:"*";inherits:false}
@property --tw-tracking{syntax:"*";inherits:false}


/*# sourceMappingURL=main.css.map*/