:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-bg:#eff6ff;--color-primary-border:#bfdbfe;--color-success:#16a34a;--color-success-bg:#dcfce7;--color-success-fg:#15803d;--color-warning:#d97706;--color-warning-bg:#fef3c7;--color-warning-fg:#92400e;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-danger-bg:#fee2e2;--color-danger-fg:#991b1b;--color-info:#0284c7;--color-info-bg:#e0f2fe;--color-info-fg:#075985;--color-bg:#f1f5f9;--color-bg-soft:#f8fafc;--color-surface:#fff;--color-border:#e2e8f0;--color-border-strong:#cbd5e1;--color-text:#0f172a;--color-text-soft:#475569;--color-text-muted:#64748b;--color-text-faint:#94a3b8;--sidebar-bg:#0f172a;--sidebar-bg-hover:#1e293b;--sidebar-fg:#cbd5e1;--sidebar-fg-strong:#fff;--sidebar-fg-muted:#64748b;--sidebar-active-bg:#2563eb;--r-sm:4px;--r:6px;--r-md:8px;--r-lg:12px;--shadow-card:0 1px 2px #0f172a0a, 0 1px 3px #0f172a0a;--shadow-pop:0 10px 25px -5px #0f172a2e;--gap-1:4px;--gap-2:8px;--gap-3:12px;--gap-4:16px;--gap-5:20px;--gap-6:24px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{color:var(--color-text)}h2{font-size:22px;font-weight:600}h3{font-size:16px;font-weight:600}h4{font-size:14px;font-weight:600}.app{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-fg);flex-direction:column;height:100vh;padding:16px 12px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #1e293b;align-items:center;gap:10px;margin-bottom:6px;padding:4px 6px 14px;display:flex}.sidebar-brand-icon{background:var(--color-primary);border-radius:var(--r);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-brand-name{color:var(--sidebar-fg-strong);margin:0;font-size:15px;font-weight:600}.sidebar-brand-sub{color:var(--sidebar-fg-muted);margin-top:1px;font-size:11px}.sidebar nav{flex-direction:column;gap:2px;display:flex}.sidebar nav a{color:var(--sidebar-fg);border-radius:var(--r);white-space:nowrap;align-items:center;gap:10px;padding:7px 10px;font-size:13px;display:flex}.sidebar nav a svg{opacity:.85;flex-shrink:0}.sidebar nav a:hover{background:var(--sidebar-bg-hover);text-decoration:none}.sidebar nav a.active{background:var(--sidebar-active-bg);color:var(--sidebar-fg-strong)}.sidebar nav a.active svg{opacity:1}.sidebar .group-label{text-transform:uppercase;color:var(--sidebar-fg-muted);letter-spacing:.6px;margin:16px 10px 4px;font-size:10px;font-weight:600}.main{flex-direction:column;min-width:0;display:flex}.topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:10;justify-content:space-between;align-items:center;padding:10px 22px;display:flex;position:sticky;top:0}.topbar-title{color:var(--color-text-muted);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.topbar-title svg{color:var(--color-primary)}.user-switcher{align-items:center;gap:10px;display:flex}.user-switcher label{color:var(--color-text-muted);font-size:12px}.user-switcher select{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);padding:5px 8px}.health-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:12px;display:inline-flex}.health-badge.ok{background:var(--color-success-bg);color:var(--color-success-fg)}.health-badge.bad{background:var(--color-danger-bg);color:var(--color-danger-fg)}.health-badge.pending{background:var(--color-border);color:var(--color-text-soft)}.content{flex:1;width:100%;max-width:1500px;padding:22px 24px;overflow-y:auto}.breadcrumbs{color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:12px;display:flex}.breadcrumbs a{color:var(--color-text-muted)}.breadcrumbs a:hover{color:var(--color-primary);text-decoration:none}.breadcrumbs .sep{color:var(--color-text-faint)}.breadcrumbs .current{color:var(--color-text);font-weight:500}.page-header h2{align-items:center;gap:10px;margin:0;display:flex}.page-header .page-desc{color:var(--color-text-muted);max-width:720px;margin-top:4px;font-size:13px}.page-header .page-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:8px 14px;margin-top:8px;font-size:13px;display:flex}.page-header .page-meta strong{color:var(--color-text);font-weight:600}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-md);box-shadow:var(--shadow-card);margin-bottom:16px;padding:16px}.card.flat{box-shadow:none}.card-title{color:var(--color-text);align-items:center;gap:8px;margin:0 0 12px;font-size:14px;font-weight:600;display:flex}.card-title svg{color:var(--color-primary)}.btn{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);cursor:pointer;height:34px;color:var(--color-text);white-space:nowrap;vertical-align:middle;justify-content:center;align-items:center;gap:6px;padding:0 13px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;transition:background .12s,border-color .12s,color .12s,box-shadow .12s;display:inline-flex}.btn:hover{background:var(--color-bg-soft);border-color:var(--color-border-strong)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.btn:disabled{opacity:.55;cursor:not-allowed}.btn svg{flex-shrink:0}.btn.primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn.primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn.success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn.success:hover{background:#15803d;border-color:#15803d}.btn.danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn.danger:hover{background:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn.warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn.warning:hover{background:#b45309;border-color:#b45309}.btn.ghost{color:var(--color-text-soft);background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--color-bg-soft);color:var(--color-text)}.btn.outline-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-danger)}.btn.outline-danger:hover{background:var(--color-danger-bg);color:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn.outline-warning{background:var(--color-surface);color:var(--color-warning);border-color:var(--color-warning)}.btn.outline-warning:hover{background:var(--color-warning-bg);color:#b45309;border-color:#b45309}.btn.sm{height:28px;padding:0 9px;font-size:12px}.btn.xs{height:22px;padding:0 7px;font-size:11px}.btn.lg{height:40px;padding:0 18px;font-size:14px}.btn.icon-only{width:34px;padding:0}.btn.icon-only.sm{width:28px}.btn.icon-only.xs{width:22px}.btn.icon-only.lg{width:40px}.btn.ghost.icon-only{color:var(--color-text-soft)}.btn.ghost.icon-only.tone-default:hover{background:var(--color-bg);color:var(--color-text)}.btn.ghost.icon-only.tone-primary:hover{background:var(--color-primary-bg);color:var(--color-primary)}.btn.ghost.icon-only.tone-success:hover{background:var(--color-success-bg);color:var(--color-success)}.btn.ghost.icon-only.tone-warning:hover{background:var(--color-warning-bg);color:var(--color-warning)}.btn.ghost.icon-only.tone-danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.btn.ghost.icon-only:disabled,.btn.ghost.icon-only:disabled:hover{color:var(--color-text-faint);cursor:not-allowed;background:0 0}.icon-btn{border-radius:var(--r);cursor:pointer;width:30px;height:30px;color:var(--color-text-soft);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:inline-flex}.icon-btn:hover{background:var(--color-bg);color:var(--color-text)}.icon-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.icon-btn.danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.icon-btn.primary:hover{background:var(--color-primary-bg);color:var(--color-primary)}.icon-btn.success:hover{background:var(--color-success-bg);color:var(--color-success)}.icon-btn.warning:hover{background:var(--color-warning-bg);color:var(--color-warning)}.action-bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.row-actions{flex-wrap:nowrap;align-items:center;gap:6px;display:inline-flex}.row-actions[data-align=right]{justify-content:flex-end}.row-actions[data-align=left]{justify-content:flex-start}.row-actions .btn{flex:none}table.data td .row-actions{white-space:nowrap}.form-actions{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:8px;margin-top:14px;padding-top:12px;display:flex}.form-actions-left{color:var(--color-text-soft);align-items:center;gap:8px;font-size:12px;display:inline-flex}.form-actions-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.form-actions-right .btn{flex:none}.form-actions:not(:has(.form-actions-left,.form-actions-right)){flex-wrap:wrap;justify-content:flex-end}.page-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}table.data{border-collapse:collapse;background:var(--color-surface);width:100%}table.data th,table.data td{text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle;padding:9px 12px;font-size:13px}table.data th{background:var(--color-bg-soft);color:var(--color-text-soft);text-transform:none;letter-spacing:0;z-index:1;font-size:12px;font-weight:600;position:sticky;top:0}table.data tr:last-child td{border-bottom:none}table.data tr:hover td{background:var(--color-bg-soft)}table.data td .row-actions{justify-content:flex-end;gap:2px;display:flex}.num{text-align:right;font-variant-numeric:tabular-nums}table.data tr.row-inactive td{color:#94837a;background:#fef9f3}table.data tr.row-inactive:hover td{background:#fef3e8}table.data tr.row-inactive td:first-child{box-shadow:inset 3px 0 #f59e0b}table.data tr.row-inactive strong,table.data tr.row-inactive code{color:#78350f}@media print{table.data tr.row-inactive td{color:#444;background:0 0}table.data tr.row-inactive td:first-child{box-shadow:none}}.table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-md);box-shadow:var(--shadow-card);margin-bottom:16px;overflow:hidden}.form-grid{grid-template-columns:200px 1fr;align-items:center;gap:12px 16px;display:grid}.form-grid label{color:var(--color-text-soft);font-size:13px}.form-grid input,.form-grid select,.form-grid textarea{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);width:100%;color:var(--color-text);padding:7px 10px;font-family:inherit;font-size:14px}.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb26}.form-grid input[disabled],.form-grid select[disabled]{background:var(--color-bg-soft);color:var(--color-text-muted);cursor:not-allowed}.form-grid input[type=checkbox]{width:16px;height:16px}.form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;margin-top:18px;padding-top:14px;display:flex}.required-mark{color:var(--color-danger);margin-left:2px;font-weight:600}.date-input{width:100%;display:block;position:relative}.date-input-row{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);align-items:stretch;width:100%;display:flex;position:relative;overflow:hidden}.date-input-row:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.date-input.is-disabled .date-input-row{background:var(--color-bg-soft)}.date-input-text{width:100%;color:var(--color-text);letter-spacing:.2px;background:0 0;border:none;outline:none;flex:auto;padding:7px 10px;font-family:inherit;font-size:14px}.date-input-text::placeholder{color:#94a3b8}.date-input-text[aria-invalid=true]{color:var(--color-danger)}.date-input-text:disabled{color:var(--color-text-muted);cursor:not-allowed}.date-input-picker{background:var(--color-bg-soft);border:none;border-left:1px solid var(--color-border-strong);width:30px;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;padding:0;display:inline-flex}.date-input-picker:hover:not(:disabled){background:var(--color-primary-bg);color:var(--color-primary)}.date-input-picker:disabled{cursor:not-allowed;opacity:.5}.date-input-native{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute;bottom:0;right:6px}.date-input-error{color:var(--color-danger);margin-top:4px;font-size:12px}.toolbar .date-input{width:auto;min-width:140px}.toolbar .date-input-text{padding:5px 8px;font-size:13px}.lookup-select{width:100%;min-width:0}.lookup-select-row{grid-template-columns:1fr 36px;align-items:stretch;gap:6px;width:100%;display:grid!important}.lookup-select-row>select{min-width:0;width:100%!important;margin:0!important}.lookup-add-btn{color:#2563eb;cursor:pointer;box-sizing:border-box;background:#eff6ff;border:1px solid #2563eb;border-radius:6px;justify-content:center;align-items:center;width:36px;height:100%;min-height:34px;padding:0;transition:background .12s,color .12s;display:inline-flex!important}.lookup-add-btn:hover:not(:disabled){color:#fff;background:#2563eb}.lookup-add-btn:disabled{color:#94a3b8;cursor:not-allowed;background:#f1f5f9;border-color:#cbd5e1}.hint{color:var(--color-text-muted);margin-top:2px;font-size:12px}.field-error{color:var(--color-danger-fg);align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.modal-bg{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;justify-content:center;align-items:flex-start;padding:60px 20px 20px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--r-md);width:100%;max-width:720px;box-shadow:var(--shadow-pop);flex-direction:column;max-height:90vh;padding:0;display:flex;overflow:hidden}.modal.lg{max-width:960px}.modal.xl{max-width:1180px}.modal-head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-head h3{margin:0;font-size:15px}.modal-body{padding:20px;overflow:auto}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.toolbar select,.toolbar input{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);color:var(--color-text);padding:7px 10px;font-size:13px}.toolbar input:focus,.toolbar select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb26}.toolbar .grow{flex:1}.search-input{border:1px solid var(--color-border-strong);border-radius:var(--r);background:var(--color-surface);flex:1;align-items:center;gap:6px;min-width:260px;padding:6px 10px;display:flex}.search-input svg{color:var(--color-text-muted);flex-shrink:0}.search-input input{background:0 0;border:none;outline:none;flex:1;padding:0;font-family:inherit;font-size:13px}.toolbar-label{color:var(--color-text-muted);align-items:center;gap:4px;font-size:12px;display:inline-flex}.error-panel{background:var(--color-danger-bg);color:var(--color-danger-fg);border-radius:var(--r);border-left:4px solid var(--color-danger-hover);align-items:flex-start;gap:8px;margin:10px 0;padding:10px 14px;font-size:13px;display:flex}.error-panel svg{flex-shrink:0;margin-top:1px}.error-panel.warn{background:var(--color-warning-bg);color:var(--color-warning-fg);border-left-color:var(--color-warning)}.error-panel.compact{margin:4px 0;padding:6px 10px;font-size:12px}.loading{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:10px;padding:24px;font-size:13px;display:flex}.loading .spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--color-text-muted);background:var(--color-bg-soft);border-radius:var(--r);flex-direction:column;align-items:center;gap:8px;padding:32px 24px;font-size:13px;display:flex}.empty svg{color:var(--color-text-faint)}.empty-title{color:var(--color-text-soft);font-weight:600}.tag{background:var(--color-border);color:var(--color-text-soft);text-transform:uppercase;letter-spacing:.3px;border-radius:999px;align-items:center;gap:4px;padding:2px 9px;font-size:11px;font-weight:600;line-height:1.5;display:inline-flex}.tag.green{background:var(--color-success-bg);color:var(--color-success-fg)}.tag.blue{background:var(--color-primary-bg);color:#1e40af}.tag.red{background:var(--color-danger-bg);color:var(--color-danger-fg)}.tag.yellow{background:var(--color-warning-bg);color:var(--color-warning-fg)}.tag.gray{background:var(--color-border);color:var(--color-text-soft)}.tag.info{background:var(--color-info-bg);color:var(--color-info-fg)}.tag.solid-primary{background:var(--color-primary);color:#fff}.help-tooltip{align-items:center;gap:4px;margin-left:4px;display:inline-flex;position:relative}.help-tooltip-block{margin:4px 0 0;display:block}.help-tooltip-btn{width:18px;height:18px;color:var(--color-text-muted,#64748b);cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;padding:0;display:inline-flex}.help-tooltip-btn:hover,.help-tooltip-btn[aria-expanded=true]{color:#1e40af;background:#e0e7ff}.help-tooltip-bubble{z-index:1000;color:#f9fafb;white-space:normal;background:#1f2937;border-radius:6px;min-width:220px;max-width:360px;margin-top:4px;padding:8px 10px;font-size:12px;line-height:1.45;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #00000026}.help-tooltip-bubble:before{content:"";border:5px solid #0000;border-bottom-color:#1f2937;position:absolute;bottom:100%;left:8px}.tag.tag-green{color:#15803d;text-transform:none;letter-spacing:0;background:#dcfce7}.tag.tag-blue{color:#1e40af;text-transform:none;letter-spacing:0;background:#dbeafe}.tag.tag-orange{color:#9a3412;text-transform:none;letter-spacing:0;background:#ffedd5}.tag.tag-red{color:#b91c1c;text-transform:none;letter-spacing:0;background:#fee2e2}.tag.tag-gray{color:#374151;text-transform:none;letter-spacing:0;background:#e5e7eb}.tag.tag-purple{color:#6d28d9;text-transform:none;letter-spacing:0;background:#ede9fe}.tag.tag-yellow{color:#92400e;text-transform:none;letter-spacing:0;background:#fef3c7}.tag[class*=tag-] svg{flex-shrink:0}.code-with-badge{white-space:nowrap;vertical-align:middle;flex-wrap:nowrap;align-items:center;gap:8px;line-height:1;display:inline-flex}.code-with-badge>strong,.code-with-badge>code{white-space:nowrap;line-height:1.2}.code-with-badge .tag{flex-shrink:0;align-items:center;height:20px;margin:0;line-height:1;display:inline-flex}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px 18px;display:grid}.summary-grid .label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.summary-grid .value{color:var(--color-text);margin-top:4px;font-size:14px;font-weight:600}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.dash-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-md);color:inherit;box-shadow:var(--shadow-card);padding:16px;transition:border-color .12s,transform .12s;display:block}.dash-card:hover{border-color:var(--color-primary);text-decoration:none;transform:translateY(-1px)}.dash-card .icon-wrap{border-radius:var(--r);background:var(--color-primary-bg);width:32px;height:32px;color:var(--color-primary);justify-content:center;align-items:center;margin-bottom:8px;display:flex}.dash-card h3{margin:0 0 4px;font-size:14px}.dash-card p{color:var(--color-text-muted);margin:0;font-size:12px;line-height:1.5}.dash-stat-num{color:var(--color-text);font-size:26px;font-weight:700}.dash-stat-num.highlight{color:var(--color-primary)}.dash-cta-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.dash-cta{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-md);color:var(--color-text);align-items:center;gap:10px;padding:12px 14px;text-decoration:none;transition:border-color .12s,background .12s;display:flex}.dash-cta:hover{border-color:var(--color-primary);background:var(--color-primary-bg);text-decoration:none}.dash-cta .icon-wrap{border-radius:var(--r);background:var(--color-primary-bg);width:34px;height:34px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-cta .label{font-size:13px;font-weight:600}.dash-cta .sub{color:var(--color-text-muted);font-size:11px}.checklist{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.checklist li{color:var(--color-text);align-items:center;gap:10px;padding:7px 0;font-size:13px;display:flex}.checklist li svg{color:var(--color-success);flex-shrink:0}.tabs{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:16px;display:flex}.tabs button{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.tabs button:hover{color:var(--color-text)}.tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tabs button .count{background:var(--color-bg);color:var(--color-text-soft);border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600}.tabs button.active .count{background:var(--color-primary-bg);color:var(--color-primary)}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:8px 4px;display:flex}.pagination .info{color:var(--color-text-muted);font-size:12px}.pagination .controls{align-items:center;gap:6px;display:flex}.pagination .page-size-select{border:1px solid var(--color-border-strong);border-radius:var(--r);padding:5px 8px;font-size:12px}.toast-container{z-index:100;flex-direction:column;gap:8px;max-width:380px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--color-text);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-pop);align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;animation:.18s ease-out toast-in;display:flex}.toast.success{background:var(--color-success)}.toast.error{background:var(--color-danger)}.toast.warn{background:var(--color-warning)}.toast.info{background:var(--color-info)}.toast svg{flex-shrink:0;margin-top:1px}.toast-close{color:#fffc;cursor:pointer;background:0 0;border:none;margin-left:4px;padding:0}.toast-close:hover{color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.confirm{width:100%}.confirm-icon{border-radius:50%;flex:none;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:12px;display:flex}.confirm-icon.danger{background:var(--color-danger-bg);color:var(--color-danger)}.confirm-icon.warn{background:var(--color-warning-bg);color:var(--color-warning)}.confirm-icon.success{background:var(--color-success-bg);color:var(--color-success)}.confirm-icon.info{background:var(--color-primary-bg);color:var(--color-primary)}.confirm-title{margin:0 0 6px;font-size:16px;font-weight:600}.confirm-msg{color:var(--color-text-soft);width:100%;min-width:0;max-width:none;margin:0 0 18px;font-size:13px;line-height:1.55}.confirm-msg p{max-width:none}.confirm-actions{border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;margin-top:16px;padding-top:14px;display:flex}.confirm-actions .btn{justify-content:center;min-width:112px;height:34px}.dropzone{border:2px dashed var(--color-border-strong);border-radius:var(--r-md);text-align:center;background:var(--color-bg-soft);color:var(--color-text-muted);cursor:pointer;flex-direction:column;align-items:center;gap:6px;padding:24px;transition:border-color .12s,background .12s;display:flex}.dropzone:hover,.dropzone.over{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary)}.dropzone svg{color:var(--color-text-muted)}.dropzone:hover svg,.dropzone.over svg{color:var(--color-primary)}.login-bg{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 60%,#2563eb 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:14px;width:100%;max-width:420px;padding:32px 36px;box-shadow:0 30px 80px #00000040}.login-brand{align-items:center;gap:12px;margin-bottom:22px;display:flex}.login-brand-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#1e40af);border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.login-brand-name{color:#0f172a;font-size:20px;font-weight:700}.login-brand-sub{color:#64748b;font-size:12px}.login-form{flex-direction:column;gap:14px;display:flex}.login-form label{color:#334155;flex-direction:column;gap:4px;font-size:13px;display:flex}.login-form input{border:1px solid #cbd5e1;border-radius:8px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .12s}.login-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.login-submit{justify-content:center;padding:10px 14px;font-size:14px;font-weight:600}.login-meta{color:#94a3b8;justify-content:space-between;margin-top:18px;font-size:11px;display:flex}.login-banner{border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;display:flex}.login-banner.info{color:#1d4ed8;background:#eff6ff}.login-banner.warn{color:#92400e;background:#fef3c7}.login-banner.err{color:#b91c1c;background:#fee2e2}.user-menu{align-items:center;gap:8px;display:flex;position:relative}.user-button{border:1px solid var(--color-border,#e5e7eb);color:var(--color-text,#1f2937);cursor:pointer;background:#fff;border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;transition:background .12s;display:inline-flex}.user-button:hover{background:#f1f5f9}.user-name{font-weight:500}.user-popover{border:1px solid var(--color-border,#e5e7eb);z-index:100;background:#fff;border-radius:10px;width:260px;padding:8px 0;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 12px 24px #0000001a}.user-popover-head{padding:10px 14px}.user-popover-section{padding:6px 14px}.user-popover hr{border:none;border-top:1px solid var(--color-border,#e5e7eb);margin:6px 0}.user-popover-item{text-align:left;width:100%;color:var(--color-text,#1f2937);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 14px;font-size:13px;text-decoration:none;display:flex}.user-popover-item:hover{background:#f1f5f9}.mock-user-select{border:1px solid var(--color-border,#e5e7eb);background:#fff;border-radius:999px;padding:4px 10px;font-size:12px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px;display:flex}.page-title{align-items:center;gap:8px;margin:0 0 4px;font-size:22px;display:inline-flex}.action-toolbar{align-items:center;gap:8px;display:flex}.search-input{border:1px solid var(--color-border,#e5e7eb);background:#fff;border-radius:8px;align-items:center;gap:4px;padding:4px 10px;display:inline-flex}.search-input input{border:none;outline:none;min-width:180px;font-size:13px}.banner{border-radius:8px;align-items:center;gap:8px;margin:12px 0;padding:10px 14px;font-size:13px;display:inline-flex}.banner.info{color:#1d4ed8;background:#eff6ff}.banner.ok{color:#166534;background:#dcfce7}.banner.warn{color:#92400e;background:#fef3c7}.banner.err{color:#b91c1c;background:#fee2e2}.form-card{border:1px solid var(--color-border,#e5e7eb);background:#fff;border-radius:10px;padding:22px}.form-card label{color:#334155;flex-direction:column;gap:4px;margin-bottom:12px;font-size:13px;display:flex}.form-card input{border:1px solid #cbd5e1;border-radius:6px;outline:none;padding:8px 10px;font-size:14px}.form-card input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.modal-bg{z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:600px;padding:22px 26px;box-shadow:0 24px 60px #0000004d}.modal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-header h3{margin:0}.modal-form-grid{grid-template-columns:1fr 1fr;gap:8px 14px;display:grid}.modal-form-grid .full{grid-column:1/-1}.modal-form-grid label{color:#334155;flex-direction:column;gap:4px;margin-bottom:4px;font-size:13px;display:flex}.modal-form-grid label>span:first-child{white-space:normal;display:block}.modal-form-grid input,.modal-form-grid select,.modal-form-grid textarea{border:1px solid #cbd5e1;border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:14px}.modal-form-grid input:focus,.modal-form-grid select:focus,.modal-form-grid textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.checkbox-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:6px 12px;display:grid}.checkbox-inline{align-items:center;gap:6px;font-size:12px;display:inline-flex;flex-direction:row!important}.user-modal-section{margin-bottom:22px}.user-modal-section:last-child{margin-bottom:0}.user-modal-section-title{color:#0f172a;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--color-border,#e5e7eb);align-items:center;gap:8px;margin-bottom:14px;padding-bottom:8px;font-size:13px;font-weight:600;display:flex}.user-modal-section-title .count{color:#475569;text-transform:none;letter-spacing:0;margin-left:auto;font-size:12px;font-weight:500}.user-modal-basic-grid{grid-template-columns:1fr 1fr;gap:14px 18px;display:grid}.user-modal-basic-grid label.field{color:#334155;flex-direction:column;gap:4px;font-size:13px;display:flex}.user-modal-basic-grid label.field>.lbl{color:#475569;font-weight:500}.user-modal-basic-grid label.field>input{color:#1f2937;background:#fff;border:1px solid #cbd5e1;border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:14px}.user-modal-basic-grid label.field>input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.user-modal-basic-grid label.field>input[disabled]{color:#94a3b8;cursor:not-allowed;background:#f8fafc}.user-modal-basic-grid .full{grid-column:1/-1}@media (width<=720px){.user-modal-basic-grid{grid-template-columns:1fr}}.toggle-switch{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:inline-flex}.toggle-switch input{opacity:0;pointer-events:none;position:absolute}.toggle-switch .track{background:#cbd5e1;border-radius:999px;width:42px;height:24px;transition:background .15s;display:inline-block;position:relative}.toggle-switch .track:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .18s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0f172a40}.toggle-switch input:checked+.track{background:#16a34a}.toggle-switch input:checked+.track:after{transform:translate(18px)}.toggle-switch input:focus-visible+.track{box-shadow:0 0 0 3px #dbeafe}.toggle-switch .label{color:#334155;font-size:13px}.toggle-switch .state-text{color:#64748b;font-size:12px}.toggle-switch input:checked~.state-text{color:#15803d;font-weight:600}.role-group{margin-bottom:18px}.role-group:last-child{margin-bottom:0}.role-group-title{color:#475569;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;font-size:12px;font-weight:600}.role-cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}@media (width<=720px){.role-cards{grid-template-columns:1fr}}.role-card{border:1px solid var(--color-border,#e5e7eb);cursor:pointer;background:#fff;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .12s,background .12s,box-shadow .12s;display:flex;position:relative}.role-card:hover{background:#f8fafc;border-color:#94a3b8}.role-card.selected{background:#eff6ff;border-color:#2563eb;box-shadow:inset 0 0 0 1px #2563eb}.role-card .role-check{color:#fff;background:#fff;border:1.5px solid #94a3b8;border-radius:4px;flex:none;justify-content:center;align-items:center;width:18px;height:18px;margin-top:2px;display:inline-flex}.role-card.selected .role-check{background:#2563eb;border-color:#2563eb}.role-card .role-body{flex:auto;min-width:0}.role-card .role-name{color:#0f172a;font-size:13px;font-weight:600;display:block}.role-card .role-desc{color:#64748b;margin-top:3px;font-size:12px;line-height:1.4}.role-card input.role-input{opacity:0;pointer-events:none;position:absolute}.role-card.disabled{opacity:.55;cursor:not-allowed}.role-card.disabled:hover{border-color:var(--color-border,#e5e7eb);background:#fff}.modul-section{border:1px solid var(--color-border,#e5e7eb);border-radius:8px;margin-bottom:10px;padding:10px 14px}.modul-section h4{color:#0f172a;margin:4px 0 8px;font-size:13px}.muted{color:#64748b}.small{font-size:11px}.toast{z-index:2000;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;display:inline-flex;position:fixed;top:16px;right:16px;box-shadow:0 6px 12px #0000001a}.toast.ok{color:#166534;background:#dcfce7}.toast.err{color:#b91c1c;background:#fee2e2}.page-loading{text-align:center;color:#64748b;padding:60px}select:not([multiple]){appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:14px 14px;padding-right:36px}select::-ms-expand{display:none}select:disabled{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E")}.toolbar select,.pagination .page-size-select,.user-switcher select,.mock-user-select{background-position:right 10px center;padding-right:28px}@media print{.sidebar,.topbar,.action-bar,.toolbar,.search-bar,.search-input,.form-actions,.pagination{display:none!important}.app,.main{display:block!important}.content{max-width:none;padding:0;overflow:visible!important}body{background:#fff}.card{box-shadow:none;page-break-inside:avoid;border:1px solid #ddd}table.data{font-size:11px}table.data th{position:static}.btn,.icon-btn{display:none!important}a{color:#000;text-decoration:none}.tabs{display:none}}
