@import "https://rsms.me/inter/inter.css";:root{--bg:#fff;--bg-soft:#f7f8fa;--bg-muted:#f1f2f5;--border:#e5e7eb;--border-strong:#d1d5db;--text:#0f172a;--text-soft:#475569;--text-muted:#94a3b8;--indigo-50:#eef2ff;--indigo-100:#e0e7ff;--indigo-500:#6366f1;--indigo-600:#4f46e5;--indigo-700:#4338ca;--indigo-800:#3730a3;--green-50:#ecfdf5;--green-600:#059669;--green-700:#047857;--orange-50:#fff7ed;--orange-600:#ea580c;--orange-700:#c2410c;--red-50:#fef2f2;--red-600:#dc2626;--red-700:#b91c1c;--gray-dark:#1f2937;--r-sm:6px;--r:8px;--r-lg:12px;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 1px #0f172a08;--shadow:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-lg:0 8px 24px #0f172a14, 0 2px 6px #0f172a0a}.civio{--bg:#fff;--bg-soft:#f7f8fa;--bg-muted:#f1f2f5;--border:#e5e7eb;--border-strong:#d1d5db;--text:#0f172a;--text-soft:#475569;--text-muted:#94a3b8;font-feature-settings:"cv11", "ss01";color:var(--text);letter-spacing:-.005em;background:var(--bg);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;text-align:left;width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.45;overflow:hidden}.civio-app{height:100vh}.civio *,.civio :before,.civio :after{box-sizing:border-box}.civio button{cursor:pointer;font-family:inherit}.civio input,.civio textarea,.civio select{font-family:inherit;font-size:inherit;color:inherit}.civio h1,.civio h2,.civio h3,.civio h4,.civio h5,.civio h6{color:var(--text);font-family:inherit}.civio-logo{letter-spacing:-.02em;color:var(--text);align-items:center;gap:8px;font-size:18px;font-weight:700;display:inline-flex}.civio-logo-mark{background:linear-gradient(135deg, var(--indigo-600), var(--indigo-800));color:#fff;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:13px;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #4338ca4d}.btn{border-radius:var(--r);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;line-height:1.2;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.btn-primary{background:var(--indigo-700);color:#fff}.btn-primary:hover{background:var(--indigo-800)}.btn-ghost{color:var(--text-soft);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-soft);color:var(--text)}.btn-secondary{color:var(--text);border-color:var(--border);background:#fff}.btn-secondary:hover{border-color:var(--border-strong);background:var(--bg-soft)}.btn-success{background:var(--green-600);color:#fff}.btn-success:hover{background:var(--green-700)}.btn-danger{background:var(--red-600);color:#fff}.btn-danger:hover{background:var(--red-700)}.btn-dark{background:var(--gray-dark);color:#fff}.btn-dark:hover{background:#111827}.btn-block{width:100%}.btn-sm{border-radius:6px;padding:5px 10px;font-size:13px}.btn-lg{padding:11px 18px;font-size:15px}.field{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--text);font-size:13px;font-weight:500}.field-label .req{color:var(--red-600);margin-left:2px}.field-help{color:var(--text-muted);font-size:12px}.field-error{color:var(--red-600);align-items:center;gap:4px;font-size:12px;display:flex}.form-alert{border-radius:var(--r);background:var(--red-50);color:var(--red-700);border:1px solid #fecaca;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.input,.textarea,.select{border-radius:var(--r);border:1px solid var(--border-strong);width:100%;color:var(--text);background:#fff;padding:9px 12px;font-size:14px;line-height:1.4;transition:border-color .12s,box-shadow .12s}.input:focus,.textarea:focus,.select:focus{border-color:var(--indigo-600);outline:none;box-shadow:0 0 0 3px #4f46e51f}.input.has-error{border-color:var(--red-600)}.input.has-error:focus{box-shadow:0 0 0 3px #dc26261f}.input-group{display:flex;position:relative}.input-group .input{padding-right:40px}.input-group-action{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.input-group-action:hover{color:var(--text);background:var(--bg-soft)}.textarea{resize:vertical;min-height:80px}.badge{border:1px solid #0000;border-radius:12px;align-items:center;gap:5px;padding:2px 8px;font-size:12px;font-weight:500;line-height:1.5;display:inline-flex}.badge-dot{border-radius:50%;width:6px;height:6px}.badge-pending{background:var(--orange-50);color:var(--orange-700);border-color:#fed7aa}.badge-pending .badge-dot{background:#f97316}.badge-approved{background:var(--green-50);color:var(--green-700);border-color:#a7f3d0}.badge-approved .badge-dot{background:#10b981}.badge-rejected{background:var(--red-50);color:var(--red-700);border-color:#fecaca}.badge-rejected .badge-dot{background:#ef4444}.badge-blocked{color:#1f2937;background:#f3f4f6;border-color:#d1d5db}.badge-blocked .badge-dot{background:#4b5563}.badge-info{background:var(--indigo-50);color:var(--indigo-700);border-color:#c7d2fe}.badge-info .badge-dot{background:var(--indigo-600)}.badge-neutral{background:var(--bg-muted);color:var(--text-soft);border-color:var(--border)}.badge-neutral .badge-dot{background:var(--text-muted)}.card{border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);background:#fff}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-body{padding:20px}.card-title{margin:0;font-size:15px;font-weight:600}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 16px}.table th{color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-soft);font-size:12px;font-weight:500}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-soft)}.table td{color:var(--text);font-size:14px}.table .cell-muted{color:var(--text-soft);font-size:13px}.table .cell-actions{text-align:right}.tabs{border-bottom:1px solid var(--border);gap:4px;display:flex}.tab{color:var(--text-soft);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:8px;margin-bottom:-1px;padding:10px 14px;font-size:14px;font-weight:500;display:inline-flex}.tab:hover{color:var(--text)}.tab.active{color:var(--indigo-700);border-bottom-color:var(--indigo-700)}.tab .count{background:var(--bg-muted);color:var(--text-soft);border-radius:10px;padding:1px 7px;font-size:12px;font-weight:500}.tab.active .count{background:var(--indigo-100);color:var(--indigo-700)}.layout{height:100%;display:flex}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;width:240px;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);padding:18px 20px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.sidebar-nav-section{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:12px 10px 6px;font-size:11px;font-weight:500}.sidebar-link{border-radius:var(--r-sm);color:var(--text-soft);cursor:pointer;align-items:center;gap:10px;padding:8px 10px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--bg-soft);color:var(--text)}.sidebar-link.active{background:var(--indigo-50);color:var(--indigo-700)}.sidebar-link svg{color:currentColor;flex-shrink:0}.sidebar-foot{border-top:1px solid var(--border);padding:12px}.sidebar-burger{border:1px solid var(--border);border-radius:var(--r-sm);width:40px;height:40px;color:var(--text-soft);cursor:pointer;background:#fff;flex-shrink:0;justify-content:center;align-items:center;display:none}.sidebar-burger:hover{background:var(--bg-soft);color:var(--text)}.main{background:var(--bg-soft);flex:1;overflow:auto}.topbar{border-bottom:1px solid var(--border);background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex}.page{padding:28px 32px}.page-header{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.page-title{letter-spacing:-.02em;margin:0;font-size:24px;font-weight:600}.page-subtitle{color:var(--text-soft);margin-top:4px;font-size:14px}.avatar{background:var(--indigo-100);width:32px;height:32px;color:var(--indigo-700);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex}.avatar-lg{width:40px;height:40px;font-size:14px}.crumb{color:var(--text-soft);cursor:pointer;align-items:center;gap:6px;margin-bottom:14px;font-size:14px;text-decoration:none;display:inline-flex}.crumb:hover{color:var(--text)}.divider{background:var(--border);height:1px;margin:16px 0}.kv{grid-template-columns:160px 1fr;align-items:baseline;gap:12px 24px;display:grid}.kv dt{color:var(--text-soft);font-size:13px}.kv dd{color:var(--text);margin:0;font-size:14px}.stat{border:1px solid var(--border);border-radius:var(--r-lg);background:#fff;padding:16px 18px}.stat-label{color:var(--text-soft);font-size:13px;font-weight:500}.stat-value{letter-spacing:-.02em;margin-top:4px;font-size:28px;font-weight:600}.stat-delta{color:var(--text-muted);margin-top:6px;font-size:12px}.empty{border:1px dashed var(--border-strong);border-radius:var(--r-lg);text-align:center;background:#fff;padding:56px 24px}.empty-illust{background:var(--indigo-50);width:88px;height:88px;color:var(--indigo-600);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 18px;display:flex}.empty-title{margin:0 0 6px;font-size:16px;font-weight:600}.empty-text{color:var(--text-soft);margin:0 0 18px}.scrollshade{overflow:auto}.placeholder-img{border:1px solid var(--border);color:var(--text-muted);background:repeating-linear-gradient(135deg,#f1f2f5 0 8px,#e5e7eb 8px 9px);justify-content:center;align-items:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;display:flex}.timeline{flex-direction:column;gap:0;display:flex}.timeline-item{gap:12px;padding-bottom:18px;display:flex;position:relative}.timeline-item:not(:last-child):before{content:"";background:var(--border);width:1px;position:absolute;top:24px;bottom:0;left:11px}.timeline-dot{border:2px solid var(--border);z-index:1;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:relative}.timeline-content{flex:1;padding-bottom:4px}.timeline-meta{color:var(--text-muted);font-size:12px}.timeline-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;font-size:13px;display:flex}.timeline-comment{color:var(--text-soft);background:var(--bg-soft);border-radius:var(--r-sm);margin-top:4px;padding:8px 10px;font-size:13px}.grid-stats{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.dash-split{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:18px;display:grid}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid-form-row{grid-template-columns:repeat(4,1fr) auto;align-items:end;gap:8px;display:grid}.modal-overlay{z-index:50;background:#0f172a73;display:flex;position:fixed;inset:0}.drawer{width:420px;max-width:100%;height:100%;box-shadow:var(--shadow-lg);background:#fff;overflow:auto}.modal{border-radius:var(--r-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);background:#fff}@media (width<=1024px){.page{padding:22px 24px}.page-title{font-size:22px}.sidebar{width:220px}.dash-split{grid-template-columns:1fr}}@media (width<=768px){.civio,.civio-app{max-width:100vw;height:auto;min-height:100vh;overflow:hidden visible}.layout{flex-direction:column;min-width:0;height:auto;min-height:100vh}.main{min-width:0;max-width:100vw}.sidebar{border-right:none;border-bottom:1px solid var(--border);z-index:10;flex-flow:wrap;align-items:center;width:100%;position:sticky;top:0}.sidebar-brand{border-bottom:none;border-right:none;flex:1;min-width:0;padding:12px 16px}.sidebar-burger{margin-right:16px;display:inline-flex}.sidebar-nav,.sidebar-foot{flex-basis:100%;order:3;width:100%;display:none}.sidebar.nav-open .sidebar-nav{border-top:1px solid var(--border);flex-direction:column;gap:2px;padding:8px;display:flex}.sidebar.nav-open .sidebar-foot{border-top:1px solid var(--border);border-left:none;padding:12px 16px;display:block}.sidebar-link.active{background:var(--indigo-50)}.main{overflow:visible}.page{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.page-title{font-size:20px}.page-subtitle{font-size:13px}.card{-webkit-overflow-scrolling:touch;overflow-x:auto}.card-header{flex-wrap:wrap;gap:8px;padding:12px 14px}.card-body{padding:14px}.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0}.kv{grid-template-columns:1fr;gap:4px 0}.kv dt{font-size:12px}.table th,.table td{padding:10px 12px;font-size:13px}.scrollshade{overflow-x:auto}.grid-stats{grid-template-columns:repeat(2,1fr);gap:10px}.grid-2{grid-template-columns:1fr}.grid-form-row{grid-template-columns:1fr 1fr}.grid-form-row>.btn{grid-column:1/-1}.drawer{width:100%;max-width:100%;padding:18px!important}.modal-overlay{padding:0}.table-cards{width:100%;display:block}.table-cards thead{display:none}.table-cards tbody{width:100%;display:block}.table-cards tr{border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);background:#fff;margin:12px 0;padding:6px 14px;display:block}.table-cards tbody tr:hover{background:#fff}.table-cards td{text-align:right;border:none;justify-content:space-between;align-items:center;gap:12px;min-height:0;padding:8px 0;display:flex}.table-cards tr td:not(:last-child){border-bottom:1px solid var(--border)}.table-cards td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);text-align:left;white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:500}.table-cards td:empty{display:none}.table-cards td.cell-actions{text-align:left;flex-wrap:wrap;justify-content:flex-end;padding-top:12px}.table-cards td.cell-actions:before{display:none}.table-cards td.cell-actions>div{flex-wrap:wrap;justify-content:flex-end}.table-cards td.cell-actions .btn{flex:1;min-width:120px}.table-cards td.cell-chevron{display:none}.table-cards td.cell-actions:has(>div:empty){display:none}.topbar{flex-wrap:wrap;gap:8px;height:auto;padding:12px 16px}.stat{padding:12px 14px}.stat-value{font-size:22px}.btn{padding:8px 12px}.btn-lg{padding:10px 14px}}@media (width<=420px){.page{padding:12px}.page-title{font-size:18px}.sidebar-brand{padding:10px 12px}.sidebar-brand .civio-logo span:not(.civio-logo-mark){display:none}}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0;overflow-x:hidden}html{overflow-x:hidden}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}
