@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700;800&family=Sora:wght@400;500;600&display=swap";:root{--primary:#245beb;--primary-dark:#1b46c5;--primary-soft:#edf4ff;--primary-hover:#1e4fd4;--secondary:#14c2a3;--secondary-soft:#e8faf5;--bg:#f4f7fb;--bg-alt:#edf1f8;--surface:#fff;--surface-hover:#fafbfd;--surface-raised:#fff;--sidebar-bg:linear-gradient(180deg, #0f1b3d 0%, #162451 50%, #1b2d63 100%);--sidebar-ink:#fff;--sidebar-muted:#ffffff8c;--sidebar-border:#ffffff14;--sidebar-hover:#ffffff12;--sidebar-active-bg:#245beb40;--sidebar-active-text:#fff;--ink:#121826;--muted:#5b6475;--subtle:#8896a6;--border:#e4eaf3;--border-strong:#c3d6e3;--success:#12b76a;--success-soft:#ecfdf3;--warning:#f79009;--warning-soft:#fffaeb;--danger:#f04438;--danger-soft:#fef3f2;--info:#2e90fa;--info-soft:#eff8ff;--accent-blue:#245beb;--accent-teal:#14c2a3;--accent-green:#12b76a;--accent-amber:#f79009;--shadow-xs:0 1px 2px #1218260a;--shadow-sm:0 1px 3px #1218260f, 0 1px 2px #1218260a;--shadow-md:0 4px 16px #12182614;--shadow-lg:0 12px 32px #1218261a;--shadow-primary:0 8px 24px #245beb2e;--surface-glow:inset 0 1px 0 #ffffff8c;--ambient-1:#245beb24;--ambient-2:#14c2a31f;--radius-xs:8px;--radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px;--radius-pill:999px;--space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:16px;--space-lg:20px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--sidebar-w:264px;--topbar-h:64px;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.2s;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--primary:#5b8def;--primary-dark:#245beb;--primary-soft:#245beb26;--primary-hover:#7ba3f5;--secondary:#2dd4b7;--secondary-soft:#14c2a31f;--bg:#0d1117;--bg-alt:#161b22;--surface:#1c2128;--surface-hover:#21262d;--surface-raised:#242a33;--sidebar-bg:linear-gradient(180deg, #070b14 0%, #0d1117 50%, #111822 100%);--sidebar-ink:#e6edf3;--sidebar-muted:#e6edf373;--sidebar-border:#ffffff0f;--sidebar-hover:#ffffff0d;--sidebar-active-bg:#5b8def33;--sidebar-active-text:#fff;--ink:#e6edf3;--muted:#8b949e;--subtle:#6e7681;--border:#30363d;--border-strong:#484f58;--success:#3fb950;--success-soft:#3fb9501f;--warning:#d29922;--warning-soft:#d299221f;--danger:#f85149;--danger-soft:#f851491f;--info:#58a6ff;--info-soft:#58a6ff1f;--accent-blue:#5b8def;--accent-teal:#2dd4b7;--accent-green:#3fb950;--accent-amber:#d29922;--shadow-xs:0 1px 2px #0003;--shadow-sm:0 1px 3px #00000040, 0 1px 2px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 12px 32px #0006;--shadow-primary:0 8px 24px #5b8def33;--surface-glow:inset 0 1px 0 #ffffff0a;--ambient-1:#5b8def2e;--ambient-2:#2dd4b71f;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=dark] .badge.neutral{color:var(--muted);background:#8b949e1f}[data-theme=dark] .badge.blue{color:#7ba3f5;background:#5b8def26}[data-theme=dark] .badge.green,[data-theme=dark] .badge.tone-success{color:#56d364;background:#3fb9501f}[data-theme=dark] .badge.amber,[data-theme=dark] .badge.tone-warning{color:#e3b341;background:#d299221f}[data-theme=dark] .badge.red,[data-theme=dark] .badge.tone-error{color:#f97066;background:#f851491f}[data-theme=dark] .badge.info{color:#79c0ff;background:#58a6ff1f}[data-theme=dark] .banner-error{color:#f97066;background:#f851491a}[data-theme=dark] .banner-info{color:#79c0ff;background:#58a6ff1a}[data-theme=dark] .banner-success{color:#56d364;background:#3fb9501a}[data-theme=dark] .banner-warning{color:#e3b341;background:#d299221a}[data-theme=dark] .data-table th{background:var(--bg-alt)}[data-theme=dark] .data-table tbody tr:hover{background:#5b8def0f}[data-theme=dark] .data-table tbody tr.is-selected{background:#5b8def1a}[data-theme=dark] .skeleton{background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border) 50%, var(--bg-alt) 75%);background-size:400px 100%}[data-theme=dark] .permission-item:has(input:checked){background:#5b8def1f;border-color:#5b8def40}[data-theme=dark] .auth-hero{background:linear-gradient(135deg,#0d1117 0%,#161b22 50%,#1c2128 100%)}[data-theme=dark] .form-field input:focus,[data-theme=dark] .form-field select:focus,[data-theme=dark] .form-field textarea:focus{box-shadow:0 0 0 3px #5b8def26}[data-theme=dark] .card.active{border-color:var(--primary);box-shadow:0 0 0 3px #5b8def1f}[data-theme=dark] .nav-item.active:before{background:var(--secondary)}[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4{color:var(--ink)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Sora,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;position:relative;overflow-x:hidden}body:before,body:after{content:"";filter:blur(80px);opacity:.9;pointer-events:none;z-index:-1;border-radius:50%;width:34rem;height:34rem;animation:14s ease-in-out infinite ambientFloat;position:fixed}body:before{background:radial-gradient(circle, var(--ambient-1), transparent 68%);top:-10rem;right:-8rem}body:after{background:radial-gradient(circle, var(--ambient-2), transparent 68%);animation-delay:-6s;bottom:-12rem;left:-12rem}#root{min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}fieldset{border:none}fieldset[disabled]{opacity:.65;pointer-events:none}h1,h2,h3,h4{color:var(--ink);font-family:Space Grotesk,system-ui,sans-serif;font-weight:700;line-height:1.2}.text-display{letter-spacing:-.5px;font-size:36px;font-weight:800}.text-h1{font-size:28px}.text-h2{font-size:22px}.text-h3{font-size:18px}.text-h4{font-size:16px;font-weight:600}.text-body{font-size:14px}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-xxs{font-size:11px}.muted{color:var(--muted)}.subtle{color:var(--subtle)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.font-heading{font-family:Space Grotesk,system-ui,sans-serif}.font-mono{font-family:SFMono-Regular,Cascadia Code,monospace;font-size:13px}.uppercase{text-transform:uppercase;letter-spacing:.6px}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-shell{grid-template-columns:var(--sidebar-w) minmax(0, 1fr);min-height:100vh;display:grid}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);z-index:30;flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow:hidden auto}.sidebar-brand{align-items:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-lg);border-bottom:1px solid var(--sidebar-border);display:flex}.sidebar-brand img{border-radius:var(--radius-sm);object-fit:cover;width:44px;height:44px}.sidebar-brand-text{flex-direction:column;min-width:0;display:flex}.sidebar-brand-name{color:var(--sidebar-ink);font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;line-height:1.2}.sidebar-brand-desc{color:var(--sidebar-muted);font-size:11px;line-height:1.3}.sidebar-nav{padding:var(--space-md) var(--space-sm);gap:var(--space-xxs);flex-direction:column;flex:1;display:flex}.nav-group{margin-bottom:var(--space-xs)}.nav-group-label{text-transform:uppercase;letter-spacing:1px;color:var(--sidebar-muted);padding:var(--space-sm) var(--space-sm) var(--space-xxs);font-size:10px;font-weight:600;display:block}.nav-item{align-items:center;gap:var(--space-sm);padding:10px var(--space-sm);border-radius:var(--radius-sm);color:var(--sidebar-muted);transition:all var(--duration) var(--ease);border:1px solid #0000;font-size:14px;font-weight:500;display:flex;position:relative}.nav-item:hover{color:var(--sidebar-ink);background:var(--sidebar-hover)}.nav-item.active{color:var(--sidebar-active-text);background:var(--sidebar-active-bg);border-color:#ffffff0f;font-weight:600}.nav-item.active:before{content:"";background:var(--secondary);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-9px}.nav-icon{opacity:.7;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{padding:var(--space-md) var(--space-sm);border-top:1px solid var(--sidebar-border)}.user-card{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--duration) var(--ease);display:flex}.user-card:hover{background:var(--sidebar-hover)}.user-avatar{color:#fff;background:#245beb4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--sidebar-ink);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--sidebar-muted);text-transform:capitalize;font-size:11px}.theme-toggle{align-items:center;gap:var(--space-sm);border-radius:var(--radius-pill);cursor:pointer;color:var(--ink);border:1px solid color-mix(in srgb, var(--border) 74%, transparent);background:color-mix(in srgb, var(--surface) 86%, transparent);box-shadow:var(--shadow-xs), var(--surface-glow);transition:transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease), border-color var(--duration) var(--ease), background var(--duration) var(--ease);padding:10px 12px;display:flex}.theme-toggle:hover{border-color:color-mix(in srgb, var(--primary) 35%, var(--border));box-shadow:var(--shadow-primary), var(--surface-glow);transform:translateY(-1px)}.theme-toggle-glyph{background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 16%, transparent), color-mix(in srgb, var(--secondary) 16%, transparent));width:34px;height:34px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.theme-toggle-copy{flex-direction:column;align-items:flex-start;min-width:0;display:flex}.theme-toggle-copy strong{color:var(--ink);font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:700}.theme-toggle-copy small{color:var(--muted);font-size:11px}.theme-toggle-track{border-radius:var(--radius-pill);background:color-mix(in srgb, var(--primary) 18%, var(--bg-alt));width:36px;height:20px;transition:background var(--duration) var(--ease);flex-shrink:0;margin-left:auto;position:relative}.theme-toggle-track:after{content:"";width:16px;height:16px;transition:transform var(--duration) var(--ease);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 4px 12px #1218262e}[data-theme=dark] .theme-toggle{background:color-mix(in srgb, var(--surface) 90%, transparent)}[data-theme=dark] .theme-toggle-glyph{color:#9ec1ff;background:linear-gradient(135deg,#5b8def2e,#2dd4b724)}[data-theme=dark] .theme-toggle-track{background:color-mix(in srgb, var(--primary) 42%, var(--bg-alt))}[data-theme=dark] .theme-toggle-track:after{transform:translate(16px)}.main-area{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.topbar{min-height:var(--topbar-h);border-bottom:1px solid var(--border);padding:14px var(--space-2xl);justify-content:space-between;align-items:center;gap:var(--space-lg);z-index:20;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:color-mix(in srgb, var(--surface) 82%, transparent);display:flex;position:sticky;top:0;box-shadow:0 10px 32px #0f172a0f}[data-theme=dark] .topbar{background:color-mix(in srgb, var(--surface) 86%, transparent)}.topbar-left{align-items:center;gap:var(--space-sm);min-width:0;display:flex}.topbar-heading{flex-direction:column;min-width:0;display:flex}.topbar-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--subtle);font-size:11px;font-weight:600}.topbar-title{color:var(--ink);font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:800}.topbar-right{align-items:center;gap:var(--space-sm);flex-wrap:wrap;flex:1;justify-content:flex-end;min-width:0;display:flex}.topbar-actions{align-items:center;gap:var(--space-sm);flex-wrap:wrap;justify-content:flex-end;margin-left:auto;display:flex}.topbar-user-pill{border-radius:var(--radius-pill);border:1px solid color-mix(in srgb, var(--border) 74%, transparent);background:color-mix(in srgb, var(--surface) 84%, transparent);box-shadow:var(--shadow-xs), var(--surface-glow);padding:7px 12px 7px 8px}.topbar-user-pill>div:last-child{flex-direction:column;display:flex}.topbar-logout-btn{color:var(--muted);border-radius:var(--radius-pill);border:1px solid color-mix(in srgb, var(--border) 74%, transparent);background:color-mix(in srgb, var(--surface) 84%, transparent);box-shadow:var(--shadow-xs), var(--surface-glow);padding-inline:14px}.topbar-logout-btn:hover{color:var(--danger);background:color-mix(in srgb, var(--danger-soft) 72%, transparent);border-color:color-mix(in srgb, var(--danger) 32%, var(--border))}.topbar-logout-btn span{display:inline-flex}.user-avatar-sm{width:30px;height:30px;font-size:12px}.topbar-search{position:relative}.topbar-search input{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--ink);width:240px;transition:all var(--duration) var(--ease);outline:none;padding:8px 16px 8px 36px;font-size:13px}.topbar-search input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px #245beb1f}.topbar-search input::placeholder{color:var(--subtle)}.topbar-search-icon{color:var(--subtle);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.page-content{padding:var(--space-2xl);gap:var(--space-xl);isolation:isolate;flex-direction:column;flex:1;width:100%;max-width:1400px;margin:0 auto;display:flex;position:relative}.page-content:before{content:"";background:radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 14%, transparent), transparent 58%), radial-gradient(circle at 80% 40%, color-mix(in srgb, var(--secondary) 12%, transparent), transparent 52%);filter:blur(28px);opacity:.95;pointer-events:none;z-index:-1;width:min(38rem,56vw);height:22rem;position:absolute;inset:0 auto auto 0}.sidebar-overlay{z-index:29;background:#12182666;display:none;position:fixed;inset:0}.mobile-menu-btn{border-radius:var(--radius-sm);width:40px;height:40px;color:var(--ink);justify-content:center;align-items:center;display:none}.mobile-menu-btn:hover{background:var(--bg-alt)}.page-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-header-left{gap:var(--space-xxs);flex-direction:column;display:flex}.page-title{color:var(--ink);align-items:center;gap:var(--space-sm);margin:0;font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700;display:flex}.page-title:before{content:"";border-radius:var(--radius-pill);background:linear-gradient(180deg, var(--primary), var(--secondary));flex-shrink:0;width:4px;height:24px}.page-subtitle{color:var(--muted);font-size:14px}.page-actions{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm), var(--surface-glow)}.section-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.section-title{margin:0;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:800}.section-subtitle{color:var(--muted);margin-top:2px;font-size:13px}.section-divider{background:var(--border);height:1px;margin:var(--space-lg) 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);transition:box-shadow var(--duration) var(--ease), border-color var(--duration) var(--ease)}.card:hover{box-shadow:var(--shadow-sm)}.card.clickable{cursor:pointer}.card.clickable:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.card.active{border-color:var(--primary);box-shadow:0 0 0 3px #245beb14}.card.soft{background:var(--bg);padding:var(--space-md);border:none;flex-direction:column;gap:2px;display:flex}.card.soft:hover{box-shadow:none}.card h3{margin:0 0 var(--space-xxs);font-size:15px;font-weight:600}.card small{color:var(--muted);font-size:13px}.card-soft{background:var(--bg);border-color:#0000}.dashboard-hero{gap:var(--space-xl);border-radius:calc(var(--radius-xl) + 4px);border:1px solid color-mix(in srgb, var(--border) 76%, transparent);background:linear-gradient(145deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--bg-alt) 94%, transparent)), radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 12%, transparent), transparent 42%);box-shadow:var(--shadow-lg), var(--surface-glow);isolation:isolate;grid-template-columns:minmax(0,1.45fr) minmax(320px,.9fr);padding:clamp(24px,3vw,36px);display:grid;position:relative;overflow:hidden}.dashboard-hero:before,.dashboard-hero:after{content:"";pointer-events:none;z-index:-1;border-radius:999px;position:absolute}.dashboard-hero:before{background:radial-gradient(circle, color-mix(in srgb, var(--primary) 20%, transparent), transparent 70%);filter:blur(18px);width:18rem;height:18rem;top:-8rem;right:-4rem}.dashboard-hero:after{background:radial-gradient(circle, color-mix(in srgb, var(--secondary) 18%, transparent), transparent 72%);filter:blur(20px);width:14rem;height:14rem;bottom:-6rem;left:-4rem}.dashboard-kicker{border-radius:var(--radius-pill);background:color-mix(in srgb, var(--primary) 10%, transparent);color:var(--primary);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-md);align-items:center;gap:8px;padding:7px 12px;font-size:11px;font-weight:700;display:inline-flex}.dashboard-hero-copy h1{letter-spacing:-.04em;max-width:12ch;margin-bottom:var(--space-md);font-size:clamp(2rem,3.5vw,3.35rem);line-height:.98}.dashboard-hero-copy p{max-width:54ch;color:var(--muted);font-size:15px}.dashboard-hero-actions{align-items:center;gap:var(--space-sm);margin-top:var(--space-xl);flex-wrap:wrap;display:flex}.dashboard-hero-panel{padding:var(--space-lg);border-radius:calc(var(--radius-lg) + 2px);border:1px solid color-mix(in srgb, var(--border) 76%, transparent);background:color-mix(in srgb, var(--surface) 86%, transparent);box-shadow:var(--shadow-md), var(--surface-glow);align-self:stretch;gap:var(--space-lg);flex-direction:column;display:flex}.dashboard-hero-panel-label{text-transform:uppercase;letter-spacing:.12em;color:var(--subtle);font-size:12px;font-weight:700}.dashboard-hero-inline-stats{gap:var(--space-sm);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.dashboard-inline-stat{border-radius:var(--radius-md);background:color-mix(in srgb, var(--bg-alt) 82%, transparent);border:1px solid color-mix(in srgb, var(--border) 72%, transparent);padding:14px}.dashboard-inline-stat strong{margin-bottom:8px;font-family:Space Grotesk,sans-serif;font-size:28px;line-height:1;display:block}.dashboard-inline-stat span{color:var(--muted);font-size:12px;display:block}.dashboard-hero-statuses{gap:var(--space-sm);flex-wrap:wrap;display:flex}.dashboard-hero-status{border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--surface) 84%, transparent), color-mix(in srgb, var(--bg-alt) 92%, transparent));border:1px solid color-mix(in srgb, var(--border) 76%, transparent);min-width:128px;padding:14px 16px}.dashboard-hero-status strong{margin-top:10px;font-family:Space Grotesk,sans-serif;font-size:24px;display:block}.dashboard-hero-loading{display:block}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);align-items:flex-start;gap:var(--space-md);transition:all var(--duration) var(--ease);border-top:3px solid var(--border);box-shadow:var(--shadow-sm), var(--surface-glow);display:flex;position:relative;overflow:hidden}.metric-card:before{content:"";background:radial-gradient(circle, color-mix(in srgb, var(--primary) 16%, transparent), transparent 62%);opacity:0;width:180px;height:180px;transition:opacity var(--duration) var(--ease);pointer-events:none;position:absolute;inset:auto -20% -55% auto}.metric-card:hover{box-shadow:var(--shadow-lg), var(--surface-glow);border-color:var(--border-strong);transform:translateY(-3px)}.metric-card:hover:before{opacity:1}.metric-card.accent-blue{border-top-color:var(--accent-blue)}.metric-card.accent-teal{border-top-color:var(--accent-teal)}.metric-card.accent-green{border-top-color:var(--accent-green)}.metric-card.accent-amber{border-top-color:var(--accent-amber)}.metric-icon{border-radius:var(--radius-sm);width:48px;height:48px;transition:transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);flex-shrink:0;justify-content:center;align-items:center;display:flex}.metric-icon.blue{background:var(--primary-soft);color:var(--primary)}.metric-icon.teal{background:var(--secondary-soft);color:var(--secondary)}.metric-icon.green{background:var(--success-soft);color:var(--success)}.metric-icon.amber{background:var(--warning-soft);color:var(--warning)}.metric-body{flex:1;min-width:0}.metric-card:hover .metric-icon{box-shadow:0 18px 36px color-mix(in srgb, var(--primary) 15%, transparent);transform:scale(1.04)}.metric-value{color:var(--ink);margin-bottom:var(--space-xxs);font-family:Space Grotesk,sans-serif;font-size:28px;font-weight:800;line-height:1}.metric-label{color:var(--muted);font-size:13px;font-weight:500}.activity-card,.budget-overview-card{background:linear-gradient(180deg, color-mix(in srgb, var(--surface) 90%, transparent), color-mix(in srgb, var(--bg-alt) 84%, transparent))}.btn{justify-content:center;align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--duration) var(--ease);white-space:nowrap;cursor:pointer;border:1px solid #0000;font-family:Space Grotesk,sans-serif;font-weight:600;line-height:1;display:inline-flex}.btn-sm{border-radius:var(--radius-xs);padding:6px 12px;font-size:12px}.btn-md{padding:10px 18px;font-size:14px}.btn-lg{padding:12px 24px;font-size:15px}.btn:not(.btn-sm):not(.btn-lg){padding:10px 18px;font-size:14px}.btn-icon{border-radius:var(--radius-xs);width:36px;height:36px;padding:0}.btn-icon.sm{width:32px;height:32px}.btn.primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-xs)}.btn.primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn.secondary{background:var(--bg-alt);color:var(--ink);border-color:var(--border)}.btn.secondary:hover{background:var(--border)}.btn.ghost{color:var(--muted);background:0 0}.btn.ghost:hover{background:var(--bg-alt);color:var(--ink)}.btn.outline{color:var(--primary);border-color:var(--primary);background:0 0}.btn.outline:hover{background:var(--primary-soft)}.btn.danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn.danger:hover{background:var(--danger-soft)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;transform:none!important}.link-button{cursor:pointer;font:inherit;color:var(--primary);background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.link-button:hover{text-decoration:underline}.link-button:disabled{opacity:.5;cursor:not-allowed}.badge{border-radius:var(--radius-pill);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:600;line-height:1.3;display:inline-flex}.badge.neutral{background:var(--bg-alt);color:var(--muted)}.badge.blue{background:var(--primary-soft);color:var(--primary)}.badge.teal{background:var(--secondary-soft);color:#0e8c74}.badge.green,.badge.tone-success{background:var(--success-soft);color:#067647}.badge.amber,.badge.tone-warning{background:var(--warning-soft);color:#b54708}.badge.red,.badge.tone-error{background:var(--danger-soft);color:#b42318}.badge.info{background:var(--info-soft);color:#175cd3}.badge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge-dot.green{background:var(--success)}.badge-dot.amber{background:var(--warning)}.badge-dot.red{background:var(--danger)}.badge-dot.blue{background:var(--primary)}.form-grid{gap:var(--space-md);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field.full{grid-column:1/-1}.form-field label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);transition:border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #245beb1f}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--subtle)}.form-field textarea{resize:vertical;min-height:90px}.form-field input:disabled,.form-field select:disabled,.form-field textarea:disabled{background:var(--bg-alt);color:var(--muted);cursor:not-allowed}.form-hint{color:var(--subtle);font-size:12px}.checkbox-row{align-items:center;gap:var(--space-xs);cursor:pointer;font-size:14px;display:flex}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);overflow:auto}.data-table{border-collapse:collapse;width:100%;min-width:600px}.data-table th,.data-table td{text-align:left;vertical-align:middle;border-bottom:1px solid var(--border);padding:12px 16px}.data-table th{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);background:var(--bg-alt);white-space:nowrap;font-size:11px;font-weight:600}.data-table tbody tr{transition:background var(--duration) var(--ease)}.data-table tbody tr:hover{background:var(--primary-soft)}.data-table tbody tr.is-selected{background:#245beb14}.data-table tbody tr:last-child td{border-bottom:none}.table-empty{text-align:center;color:var(--muted);padding:var(--space-2xl)}.banner{align-items:flex-start;gap:var(--space-sm);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);border-left:4px solid #0000;font-size:14px;display:flex}.banner-error{background:var(--danger-soft);border-left-color:var(--danger);color:#912018}.banner-info{background:var(--info-soft);border-left-color:var(--info);color:#175cd3}.banner-success{background:var(--success-soft);border-left-color:var(--success);color:#067647}.banner-warning{background:var(--warning-soft);border-left-color:var(--warning);color:#b54708}.pagination-row{justify-content:space-between;align-items:center;gap:var(--space-md);color:var(--muted);font-size:13px;display:flex}.pagination-buttons{gap:var(--space-xs);display:flex}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);justify-content:center;align-items:center;gap:var(--space-sm);flex-direction:column;min-height:200px;display:flex}.empty-state-icon{background:var(--bg-alt);width:56px;height:56px;color:var(--subtle);margin-bottom:var(--space-xs);border-radius:50%;justify-content:center;align-items:center;display:flex}.empty-state h3{margin:0;font-size:16px;font-weight:600}.empty-state p{color:var(--muted);max-width:360px;font-size:14px}.grid-2{gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.grid-3{gap:var(--space-lg);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.grid-4{gap:var(--space-lg);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.list{gap:var(--space-sm);flex-direction:column;display:flex}.inline{align-items:center;gap:var(--space-sm);display:inline-flex}.flex-between{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.monitoring-filters{gap:var(--space-sm);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.monitoring-layout{gap:var(--space-lg);grid-template-columns:minmax(0,1.2fr) minmax(360px,.9fr);display:grid}.monitoring-list,.monitoring-detail{gap:var(--space-md);flex-direction:column;min-height:500px;display:flex}.detail-grid{gap:var(--space-sm);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.detail-item{padding:var(--space-sm);background:var(--bg);border-radius:var(--radius-xs)}.detail-item label{text-transform:uppercase;letter-spacing:.4px;color:var(--subtle);margin-bottom:var(--space-xxs);font-size:11px;font-weight:600;display:block}.detail-item strong{color:var(--ink);font-size:14px;font-weight:600}.task-config{gap:var(--space-xl);flex-direction:column;display:flex}.tab-bar{gap:var(--space-xs);border-bottom:2px solid var(--border);padding-bottom:0;display:flex;overflow-x:auto}.tab-link{padding:var(--space-sm) var(--space-md);color:var(--muted);cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:600}.tab-link:hover{color:var(--ink)}.tab-link.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-link:disabled{opacity:.4;cursor:not-allowed}.task-config-body{gap:var(--space-lg);flex-direction:column;display:flex}.calendar-header{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.calendar-head{text-transform:uppercase;letter-spacing:.5px;color:var(--subtle);text-align:center;padding:var(--space-xs) 0;font-size:11px;font-weight:600}.calendar-day{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);text-align:left;cursor:pointer;min-height:56px;transition:all var(--duration) var(--ease);flex-direction:column;justify-content:space-between;padding:6px;font-family:inherit;font-size:13px;display:flex}.calendar-day:hover{border-color:var(--primary);background:var(--primary-soft)}.calendar-day.is-empty{border:1px dashed var(--border);cursor:default;background:0 0}.calendar-day.is-empty:hover{border-color:var(--border);background:0 0}.calendar-day.is-selected{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px #245beb1f}.calendar-count{background:var(--primary);color:#fff;border-radius:var(--radius-pill);align-self:flex-end;padding:2px 7px;font-size:11px;font-weight:600}.report-sections{grid-template-columns:repeat(var(--section-cols,1), minmax(0, 1fr));gap:var(--space-md);display:grid}.report-section-fields{grid-template-columns:repeat(var(--field-cols,1), minmax(0, 1fr));gap:var(--space-md);display:grid}.report-logo{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);object-fit:contain;width:48px;height:48px;padding:4px}.photo-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.photo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-xs);gap:var(--space-xs);transition:box-shadow var(--duration) var(--ease);flex-direction:column;display:flex}.photo-card:hover{box-shadow:var(--shadow-sm)}.photo-card-trigger{cursor:pointer;text-align:left;background:0 0;border:0;padding:0}.photo-card img{border-radius:var(--radius-xs);object-fit:cover;width:100%;height:120px}.photo-card-title{color:var(--muted);padding:0 var(--space-xxs);font-size:12px;line-height:1.35}.photo-description-input{resize:vertical;border-radius:var(--radius-sm);border:1px solid var(--border);width:100%;min-height:80px;font:inherit;color:var(--ink);background:var(--surface);padding:10px 12px;font-size:13px}.photo-description-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #245beb1f}.signature-pad canvas{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-sm);touch-action:none;width:100%;height:160px}.signature-pad canvas.is-disabled{opacity:.5;pointer-events:none}.address-field{position:relative}.autocomplete-list{z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-height:220px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow:auto}.autocomplete-item{text-align:left;cursor:pointer;width:100%;color:var(--ink);transition:background var(--duration) var(--ease);background:0 0;border:none;padding:10px 14px;font-family:inherit;font-size:14px;display:block}.autocomplete-item:hover{background:var(--primary-soft)}.permission-grid{gap:var(--space-xs);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.permission-item{align-items:center;gap:var(--space-xs);padding:10px var(--space-sm);border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);transition:all var(--duration) var(--ease);font-size:13px;display:flex}.permission-item:has(input:checked){background:var(--primary-soft);border-color:#245beb33}.auth-page{background:var(--bg);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-hero{background:linear-gradient(140deg, var(--primary) 0%, var(--primary-dark) 38%, #0e2b6b 100%);padding:var(--space-3xl);color:#fff;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-hero:before{content:"";background:radial-gradient(circle,#14c2a333,#0000 70%);width:500px;height:500px;position:absolute;top:-100px;right:-100px}.auth-hero:after{content:"";background:radial-gradient(circle,#2e90fa26,#0000 70%);width:400px;height:400px;position:absolute;bottom:-80px;left:-80px}.auth-hero-content{z-index:1;max-width:520px;position:relative}.auth-hero-badge{border-radius:var(--radius-pill);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--space-lg);background:#ffffff1f;border:1px solid #ffffff29;align-items:center;padding:8px 14px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 18px 48px #07123038}.auth-hero img{border-radius:var(--radius-lg);width:88px;height:88px;margin:0 0 var(--space-xl);animation:8s ease-in-out infinite floatCard;box-shadow:0 22px 54px #00000052}.auth-hero h2{color:#fff;margin-bottom:var(--space-sm);max-width:10ch;font-size:clamp(2.1rem,3vw,3.25rem);font-weight:800}.auth-hero p{color:#ffffffbf;max-width:48ch;font-size:15px;line-height:1.6}.auth-hero-panels{gap:var(--space-sm);margin-top:var(--space-2xl);display:grid}.auth-hero-panel{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #ffffff1f;padding:16px 18px;animation:10s ease-in-out infinite floatCard;box-shadow:0 18px 46px #0712302e}.auth-hero-panel:nth-child(2){animation-delay:-3s}.auth-hero-panel:nth-child(3){animation-delay:-6s}.auth-hero-panel span{letter-spacing:.12em;text-transform:uppercase;color:#ffffff9e;margin-bottom:8px;font-size:11px;font-weight:700;display:block}.auth-hero-panel strong{color:#fff;font-size:14px;line-height:1.5}.auth-form-side{padding:var(--space-3xl) var(--space-2xl);justify-content:center;align-items:center;display:flex}.auth-form-shell{gap:var(--space-lg);flex-direction:column;width:100%;max-width:560px;display:flex}.auth-theme-toggle{align-self:flex-end}.auth-card{border-radius:calc(var(--radius-xl) + 2px);border:1px solid color-mix(in srgb, var(--border) 76%, transparent);background:color-mix(in srgb, var(--surface) 92%, transparent);width:100%;max-width:440px;box-shadow:var(--shadow-lg), var(--surface-glow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);padding:clamp(24px,3vw,34px)}.auth-card-wide{max-width:560px}.auth-brand{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-2xl);display:flex}.auth-brand img{border-radius:var(--radius-sm);width:48px;height:48px}.auth-brand strong{font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;display:block}.auth-brand span{color:var(--muted);font-size:12px;display:block}.auth-copy{margin-bottom:var(--space-xl)}.auth-copy h1{margin:0 0 var(--space-xs);font-size:28px;font-weight:800}.auth-tabs{gap:var(--space-xs);margin-bottom:var(--space-xl);background:var(--bg-alt);border-radius:var(--radius-sm);grid-template-columns:repeat(2,1fr);padding:4px;display:grid}.auth-tabs .tab{border-radius:var(--radius-xs);cursor:pointer;color:var(--muted);transition:all var(--duration) var(--ease);background:0 0;border:none;padding:10px;font-size:14px;font-weight:600}.auth-tabs .tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-form label{color:var(--ink);flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.auth-form input{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);transition:border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);outline:none;padding:12px 14px;font-family:inherit;font-size:14px}.auth-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #245beb1f}.auth-form input::placeholder{color:var(--subtle)}.auth-form input:disabled{background:var(--bg-alt);color:var(--muted)}.auth-note{margin-top:var(--space-md);text-align:center;color:var(--muted);font-size:13px}.auth-helper{margin:var(--space-xxs) 0 0;color:var(--muted);font-size:13px}.auth-links{margin-top:var(--space-lg);gap:var(--space-sm);flex-direction:column;display:flex}.auth-link-row{gap:var(--space-md);flex-wrap:wrap;display:flex}.auth-loading{min-height:100vh;padding:var(--space-2xl);justify-content:center;align-items:center;display:flex}.user-pill{align-items:center;gap:var(--space-xs);display:flex}.user-pill span{font-size:13px;font-weight:600}.user-pill small{color:var(--muted);text-transform:capitalize;font-size:11px}.filter-bar{align-items:center;gap:var(--space-sm);flex-wrap:wrap;justify-content:flex-end;display:flex}.filter-select{text-transform:uppercase;letter-spacing:.5px;color:var(--subtle);flex-direction:column;gap:3px;font-size:10px;font-weight:600;display:flex}.filter-select select,.filter-select input{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);color:var(--ink);cursor:pointer;transition:border-color var(--duration) var(--ease);outline:none;padding:7px 12px;font-family:inherit;font-size:13px}.filter-select select:focus,.filter-select input:focus{border-color:var(--primary)}.stagger>*{opacity:0;animation:fadeUp .4s var(--ease) forwards}.stagger>:first-child{animation-delay:30ms}.stagger>:nth-child(2){animation-delay:60ms}.stagger>:nth-child(3){animation-delay:90ms}.stagger>:nth-child(4){animation-delay:.12s}.stagger>:nth-child(5){animation-delay:.15s}.stagger>:nth-child(6){animation-delay:.18s}.stagger>:nth-child(7){animation-delay:.21s}.stagger>:nth-child(8){animation-delay:.24s}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes ambientFloat{0%,to{transform:translate(0,0)scale(1)}50%{transform:translate(16px,-18px)scale(1.04)}}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.skeleton{background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border) 50%, var(--bg-alt) 75%);border-radius:var(--radius-xs);background-size:400px 100%;animation:1.5s infinite shimmer}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (width<=1200px){:root{--sidebar-w:240px}.dashboard-hero{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{width:280px;height:100vh;transition:left .3s var(--ease);z-index:31;position:fixed;left:-280px}.sidebar.open{left:0}.sidebar-overlay{display:none}.sidebar-overlay.visible{display:block}.mobile-menu-btn{display:flex}.topbar{padding:14px var(--space-md)}.page-content{padding:var(--space-lg)}.grid-2,.grid-3,.grid-4,.form-grid,.detail-grid,.permission-grid,.monitoring-filters,.report-sections,.report-section-fields,.monitoring-layout,.auth-page{grid-template-columns:1fr}.auth-hero{display:none}.auth-form-side{padding:var(--space-xl) var(--space-lg)}.page-header{flex-direction:column;align-items:flex-start}.filter-bar{flex-direction:column;align-items:stretch}.topbar-search input{width:100%;min-width:0}.topbar-right{flex-wrap:wrap}.topbar-actions{justify-content:space-between;width:100%}.topbar-theme-toggle{flex:auto;min-width:0}.topbar-user-pill{margin-left:auto}}@media (width<=600px){.page-content{padding:var(--space-md);gap:var(--space-md)}.section,.metric-card{padding:var(--space-md)}.metric-value{font-size:22px}.dashboard-hero{padding:var(--space-lg)}.dashboard-hero-copy h1{max-width:none;font-size:2.2rem}.dashboard-hero-inline-stats{grid-template-columns:1fr}.topbar-theme-toggle .theme-toggle-copy,.topbar-user-pill,.topbar-logout-btn span{display:none}.topbar-theme-toggle,.topbar-logout-btn{padding-inline:10px}.tab-bar{gap:0}.tab-link{padding:var(--space-xs) var(--space-sm);font-size:13px}.page-title{font-size:20px}.auth-form-side{padding:var(--space-lg) var(--space-md)}.auth-form-shell{gap:var(--space-md)}}@media print{.sidebar,.topbar,.page-actions{display:none!important}.app-shell{grid-template-columns:1fr!important}.page-content{padding:0!important}.section{box-shadow:none!important;border:none!important}}
