@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size: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:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-slate-50:#f8fafc;--color-slate-100:#f1f5f9;--color-slate-200:#e2e8f0;--color-slate-300:#cad5e2;--color-slate-500:#62748e;--color-slate-700:#314158;--color-slate-900:#0f172b;--color-gray-200:#e5e7eb;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-2xl:42rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-md:.375rem;--radius-lg:.5rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-slate-50:lab(98.1434% -.369519 -1.05966);--color-slate-100:lab(96.286% -.852436 -2.46847);--color-slate-200:lab(91.7353% -.998765 -4.76968);--color-slate-300:lab(84.7652% -1.94535 -7.93337);--color-slate-500:lab(48.0876% -2.03595 -16.5814);--color-slate-700:lab(26.9569% -1.47016 -15.6993);--color-slate-900:lab(7.78673% 1.82345 -15.0537);--color-gray-200:lab(91.6229% -.159115 -2.26791)}}}@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%;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;-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}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::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]){appearance:button}::file-selector-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{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-4{top:calc(var(--spacing) * 4)}.right-4{right:calc(var(--spacing) * 4)}.z-30{z-index:30}.z-50{z-index:50}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mt-auto{margin-top:auto}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.-ml-2{margin-left:calc(var(--spacing) * -2)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-20{height:calc(var(--spacing) * 20)}.h-\[50px\]{height:50px}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-\[var\(--card-border\)\]{border-color:var(--card-border)}.border-slate-200{border-color:var(--color-slate-200)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab, red, red)){.bg-black\/50{background-color:color-mix(in oklab, var(--color-black) 50%, transparent)}}.bg-gray-200{background-color:var(--color-gray-200)}.bg-slate-50{background-color:var(--color-slate-50)}.bg-slate-900\/50{background-color:#0f172b80}@supports (color:color-mix(in lab, red, red)){.bg-slate-900\/50{background-color:color-mix(in oklab, var(--color-slate-900) 50%, transparent)}}.bg-white{background-color:var(--color-white)}.p-2{padding:calc(var(--spacing) * 2)}.p-6{padding:calc(var(--spacing) * 6)}.px-4{padding-inline:calc(var(--spacing) * 4)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.text-center{text-align:center}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-slate-300{color:var(--color-slate-300)}.text-slate-500{color:var(--color-slate-500)}.text-slate-700{color:var(--color-slate-700)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.group-hover\:text-\[var\(--primary\)\]:is(:where(.group):hover *){color:var(--primary)}.hover\:border-\[var\(--primary\)\]:hover{border-color:var(--primary)}.hover\:bg-slate-100:hover{background-color:var(--color-slate-100)}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-sm:hover{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:64rem){.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:hidden{display:none}.lg\:flex-1{flex:1}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:justify-start{justify-content:flex-start}.lg\:text-right{text-align:right}}}:root{--primary:#1d4ed8;--primary-hover:#1e40af;--primary-light:#dbeafe;--primary-foreground:#fff;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-active:#2563eb;--sidebar-active-bg:#1d3a6e;--sidebar-hover:#334155;--sidebar-width:240px;--header-bg:#fff;--header-border:#e2e8f0;--header-height:60px;--background:#f1f5f9;--card-bg:#fff;--card-border:#e2e8f0;--card-shadow:0px 8px 24px #959da526;--foreground:#0f172a;--muted:#64748b;--muted-bg:#f8fafc;--success:#16a34a;--success-bg:#f0fdf4;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#0284c7;--info-bg:#e0f2fe;--input-border:#cbd5e1;--input-focus:#2563eb;--border-radius:8px;--border-radius-sm:6px;--border-radius-lg:12px}*{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:.9375rem;line-height:1.6}.layout-sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:40;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.layout-sidebar.open{transform:translate(0)}.layout-main{flex-direction:column;flex:1;min-height:100vh;margin-left:0;transition:margin-left .3s;display:flex}@media (min-width:1024px){.layout-sidebar{transform:translate(0)}.layout-main{margin-left:var(--sidebar-width)}}.layout-header{height:var(--header-height);background:var(--header-bg);border-bottom:1px solid var(--header-border);z-index:30;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.layout-content{flex:1;padding:1.5rem}.sidebar-logo{border-bottom:1px solid #334155;padding:1.25rem 1rem}.sidebar-logo h1{color:#f8fafc;letter-spacing:.01em;font-size:1rem;font-weight:700}.sidebar-logo p{color:#94a3b8;margin-top:2px;font-size:.75rem}.sidebar-nav{flex:1;padding:.75rem .5rem;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background-color:#475569;border-radius:20px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background-color:#64748b}.sidebar-nav-label{color:#64748b;letter-spacing:.08em;text-transform:uppercase;padding:.5rem .5rem .25rem;font-size:.6875rem;font-weight:600}.sidebar-nav-item{border-radius:var(--border-radius-sm);color:var(--sidebar-text);cursor:pointer;align-items:center;gap:.625rem;margin-bottom:2px;padding:.5625rem .75rem;font-size:.875rem;font-weight:400;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-nav-item:hover{background:var(--sidebar-hover);color:#f1f5f9}.sidebar-nav-item.active{background:var(--sidebar-active-bg);color:#93c5fd;font-weight:500}.sidebar-nav-item.active svg{color:#60a5fa}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);margin-bottom:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.card-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.card-title{color:var(--foreground);font-size:1rem;font-weight:600}.card-body{padding:1.25rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.stats-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius);box-shadow:var(--card-shadow);align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.stats-icon{border-radius:var(--border-radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;display:flex}.stats-value{color:var(--foreground);font-size:1.5rem;font-weight:700;line-height:1}.stats-label{color:var(--muted);margin-top:.25rem;font-size:.8125rem}.btn{border-radius:var(--border-radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--muted-bg);color:var(--foreground);border:1px solid var(--card-border)}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-ghost{color:var(--muted);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--muted-bg);color:var(--foreground)}.btn-sm{padding:.3125rem .625rem;font-size:.8125rem}.btn-icon{border-radius:var(--border-radius-sm);padding:.4375rem}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--foreground);font-size:.875rem;font-weight:500}.form-label .required{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{border:1px solid var(--input-border);border-radius:var(--border-radius-sm);width:100%;color:var(--foreground);background:#fff;outline:none;padding:.5625rem .75rem;font-family:inherit;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--input-focus);box-shadow:0 0 0 3px #2563eb1f}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--danger)}.form-error{color:var(--danger);font-size:.8125rem}.form-hint{color:var(--muted);font-size:.8125rem}.form-textarea{resize:vertical;min-height:80px}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.table-wrapper{border-radius:var(--border-radius);border:1px solid var(--card-border);max-height:70vh;overflow:auto}.data-table{border-collapse:collapse;width:100%;min-width:max-content;font-size:.875rem}.data-table th{text-align:left;color:var(--muted);border-bottom:1px solid var(--card-border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:2;background:#f1f5f9;padding:.75rem 1rem;font-size:.8125rem;font-weight:600;position:sticky;top:0}.data-table th:hover{color:var(--foreground);background:#e2e8f0}.data-table th:first-child{z-index:4;background:#f1f5f9;position:sticky;top:0;left:0}.data-table td:first-child{z-index:1;background:#fff;position:sticky;left:0}.data-table tr:hover td:first-child{background:#f8fafc}.data-table th.sorted{color:var(--primary)}.data-table td{color:var(--foreground);vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.75rem 1rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fafc}.table-actions{border-bottom:1px solid var(--card-border);flex-direction:column;gap:.75rem;padding:.875rem 1.25rem;display:flex}@media (min-width:768px){.table-actions{flex-direction:row;justify-content:space-between;align-items:center}}.table-search{width:100%;position:relative}@media (min-width:768px){.table-search{width:auto;min-width:220px}}.table-search svg{color:var(--muted);pointer-events:none;position:absolute;top:50%;left:.625rem;transform:translateY(-50%)}.table-search input{width:100%;padding-left:2.25rem}.table-pagination{border-top:1px solid var(--card-border);color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:.75rem 1.25rem;font-size:.8125rem;display:flex}@media (min-width:1024px){.table-pagination{flex-direction:row;justify-content:space-between;gap:.5rem}}.table-pagination-controls{align-items:center;gap:.375rem;display:flex}.table-empty{text-align:center;color:var(--muted);padding:3rem 1rem}.breadcrumb{color:var(--muted);align-items:center;gap:.375rem;margin-bottom:1.25rem;font-size:.8125rem;display:flex}.breadcrumb a{color:var(--muted);text-decoration:none}.breadcrumb a:hover{color:var(--primary)}.breadcrumb .current{color:var(--foreground);font-weight:500}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;width:100%;margin-bottom:1.25rem;display:flex}@media (min-width:768px){.page-header{flex-direction:row;justify-content:space-between;align-items:center}}.page-title{color:var(--foreground);font-size:1.25rem;font-weight:700}.page-subtitle{color:var(--muted);margin-top:.125rem;font-size:.875rem}.badge{white-space:nowrap;border-radius:100px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success);border:1px solid #bbf7d0}.badge-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #fde68a}.badge-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.badge-info{background:var(--info-bg);color:var(--info);border:1px solid #bae6fd}.badge-default{color:var(--muted);background:#f1f5f9;border:1px solid #e2e8f0}.badge-resiko-tinggi{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}.badge-resiko-sedang{color:#d97706;background:#fef3c7;border:1px solid #fde68a}.badge-resiko-rendah{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.badge-resiko-illegal{color:#374151;background:#f3f4f6;border:1px solid #e2e8f0}.tabs{border-bottom:2px solid var(--card-border);gap:0;margin-bottom:1.25rem;display:flex}.tab-item{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.375rem;margin-bottom:-2px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s;display:flex}.tab-item:hover{color:var(--foreground)}.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.alert{border-radius:var(--border-radius-sm);align-items:flex-start;gap:.75rem;margin-bottom:1rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.alert-warning{background:var(--warning-bg);color:#92400e;border:1px solid #fde68a}.alert-danger{background:var(--danger-bg);color:#991b1b;border:1px solid #fecaca}.alert-success{background:var(--success-bg);color:#14532d;border:1px solid #bbf7d0}.alert-info{background:var(--info-bg);color:#0c4a6e;border:1px solid #bae6fd}.modal-overlay{z-index:100;background:#0f172a80;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{border-radius:var(--border-radius-lg);background:#fff;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-title{font-size:1.0625rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--card-border);justify-content:flex-end;align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.searchable-select{position:relative}.searchable-select-dropdown{border:1px solid var(--input-border);border-radius:var(--border-radius-sm);z-index:50;background:#fff;max-height:260px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001f}.searchable-select-item{cursor:pointer;padding:.5rem .75rem;font-size:.875rem;transition:background .1s}.searchable-select-item:hover{background:var(--primary-light)}.searchable-select-item.create-new{color:var(--primary);border-top:1px solid var(--card-border);align-items:center;gap:.375rem;font-weight:500;display:flex}.searchable-select-item.selected{background:var(--primary-light);color:var(--primary)}.filters-bar{border-bottom:1px solid var(--card-border);background:var(--muted-bg);flex-wrap:wrap;align-items:center;gap:.75rem;padding:.875rem 1.25rem;display:flex}.filter-chip{border:1px solid var(--card-border);cursor:pointer;white-space:nowrap;background:#fff;border-radius:100px;align-items:center;gap:.375rem;padding:.3125rem .625rem;font-size:.8125rem;transition:border-color .15s,background .15s;display:flex}.filter-chip:hover{border-color:var(--primary)}.filter-chip.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:500}.detail-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.detail-field{flex-direction:column;gap:.25rem;display:flex}.detail-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8125rem;font-weight:500}.detail-value{color:var(--foreground);font-size:.9375rem}.detail-value.empty{color:var(--muted);font-style:italic}.spinner{border:2px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;border-radius:4px;animation:1.2s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.login-page{background-image:url(/login-bg.jpg);background-position:50%;background-size:cover;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-page:before{content:"";background:#0f172a8c;position:absolute;inset:0}.login-card{z-index:1;border-radius:var(--border-radius-lg);background:#fff;width:100%;max-width:420px;padding:2.5rem;position:relative;box-shadow:0 25px 60px #00000040}.login-logo{text-align:center;margin-bottom:1.5rem}.login-logo h1{color:var(--foreground);margin-top:.75rem;font-size:1.25rem;font-weight:700}.login-logo p{color:var(--muted);margin-top:.25rem;font-size:.8125rem}.map-container{border-radius:var(--border-radius);border:1px solid var(--card-border);width:100%;height:320px;overflow:hidden}.dropzone{border:2px dashed var(--input-border);border-radius:var(--border-radius);text-align:center;cursor:pointer;padding:3rem 2rem;transition:border-color .15s,background .15s}.dropzone:hover,.dropzone.dragover{border-color:var(--primary);background:var(--primary-light)}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-col{flex-direction:column}.flex-1{flex:1}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-muted{color:var(--muted)}.text-danger{color:var(--danger)}.text-primary{color:var(--primary)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.section-divider{border:none;border-top:1px solid var(--card-border);margin:1.5rem 0}.recent-nppbkc-row:hover{background:var(--primary-light)}.form-hint{color:var(--muted);margin-top:.25rem;font-size:.75rem;display:block}.form-input.error,.form-textarea.error{border-color:var(--danger);box-shadow:0 0 0 3px #dc26261a}.form-error{color:var(--danger);margin-top:.25rem;font-size:.75rem;display:block}.date-input-wrapper,.date-input-wrapper .react-datepicker-wrapper{width:100%}.react-datepicker-popper{z-index:999!important}.react-datepicker{border:1px solid var(--card-border);border-radius:var(--border-radius);font-family:Inter,sans-serif;box-shadow:0 4px 16px #0000001f}.react-datepicker__header{background:var(--primary);border-radius:var(--border-radius) var(--border-radius) 0 0;border-bottom:none}.react-datepicker__current-month,.react-datepicker__day-name{color:#fff}.react-datepicker__navigation-icon:before{border-color:#fff}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background:var(--primary);border-radius:50%}.react-datepicker__day:hover{background:var(--primary-light);border-radius:50%}.react-datepicker__close-icon:after{background-color:var(--muted);width:18px;height:18px;font-size:14px}.react-datepicker__year-select,.react-datepicker__month-select{color:#fff;background:#fff3;border:1px solid #fff6;border-radius:4px;padding:2px 4px;font-size:.8125rem}.page-loading-bar{background:var(--primary);z-index:9999;transform-origin:0;height:3px;animation:2s ease-in-out infinite loading-bar;position:fixed;top:0;left:0;right:0}@keyframes loading-bar{0%{opacity:1;transform:scaleX(0)}60%{opacity:1;transform:scaleX(.8)}to{opacity:0;transform:scaleX(1)}}.page-spinner-overlay{z-index:9998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffffa6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@media (min-width:1024px){.page-loading-bar,.page-spinner-overlay{left:var(--sidebar-width)}}.spinner-center{flex-direction:column;align-items:center;gap:.75rem;display:flex}.spinner-center .spinner{border-width:3px;width:40px;height:40px}.spinner-center span{color:var(--muted);font-size:.875rem}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@keyframes pulse{50%{opacity:.5}}
