:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#eef2ff;--primary-border:#c7d2fe;--background:#f9fafb;--surface:#fff;--surface-soft:#f9fafb;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--border:#e5e7eb;--border-strong:#d1d5db;--danger:#dc2626;--danger-light:#fef2f2;--danger-border:#fecaca;--success:#059669;--success-light:#ecfdf5;--success-border:#a7f3d0;--warning:#d97706;--warning-light:#fffbeb;--warning-border:#fde68a;--sidebar-width:264px;--header-height:60px;--drawer-width:520px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #1018280d;--shadow-md:0 4px 12px #10182814;--shadow-lg:0 16px 40px #10182824;--ring:0 0 0 3px #4f46e529;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--font-xs:.75rem;--font-sm:.875rem;--font-md:.9375rem;--font-base:1rem;--font-lg:1.125rem}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background-color:var(--background);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-size:var(--font-sm);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}a{color:var(--primary);text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db padding-box content-box;border:2px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#9ca3af padding-box content-box}.app-container{width:100vw;height:100vh;display:flex;overflow:hidden}.app-container--col{flex-direction:column}.app-body{flex:1;min-height:0;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{background-color:var(--background);flex-direction:column;flex:1;min-width:0;min-height:0;padding:clamp(1rem,1.4vw,1.75rem);display:flex;overflow-y:auto}.page-content>.module-page{flex:1;min-height:0}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex}.sidebar__brand{border-bottom:1px solid var(--border);height:var(--header-height);align-items:center;gap:.7rem;padding:1.1rem 1.25rem;display:flex}.sidebar__logo{background:var(--primary);border-radius:var(--radius-md);color:#fff;width:34px;height:34px;font-weight:700;font-size:var(--font-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar__brand-title{color:var(--text-primary);letter-spacing:-.01em;font-size:1.05rem;font-weight:700}.sidebar__nav{flex:1;padding:.85rem .7rem;overflow-y:auto}.sidebar__section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:.75rem 0 .4rem;padding:0 .75rem;font-size:.68rem;font-weight:600}.sidebar__list{flex-direction:column;gap:2px;list-style:none;display:flex}.nav-item{border-radius:var(--radius-md);width:100%;color:var(--text-secondary);font-weight:500;font-size:var(--font-sm);text-align:left;align-items:center;gap:.7rem;padding:.55rem .75rem;transition:background .15s,color .15s;display:flex;position:relative}.nav-item svg{color:var(--text-muted);flex-shrink:0;transition:color .15s}.nav-item:hover{background:var(--surface-soft);color:var(--text-primary)}.nav-item:hover svg{color:var(--text-secondary)}.nav-item--active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-item--active svg{color:var(--primary)}.nav-item--active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar__footer{border-top:1px solid var(--border);padding:.85rem}.sidebar__user{align-items:center;gap:.6rem;margin-bottom:.6rem;padding:.35rem;display:flex}.sidebar__avatar{background:var(--primary-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.sidebar__user-text{min-width:0;overflow:hidden}.sidebar__user-label{font-size:var(--font-xs);color:var(--text-muted);font-weight:500}.sidebar__user-email{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.app-header{height:var(--header-height);border-bottom:1px solid var(--border);background:var(--surface);z-index:70;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:0 clamp(1rem,1.4vw,1.75rem) 0 .7rem;display:flex}.app-header__left{align-items:center;gap:.9rem;min-width:0;display:flex}.app-header__brand{flex-shrink:0;align-items:center;gap:.6rem;padding-left:.3rem;display:flex}.app-header__brand-title{letter-spacing:-.01em;color:var(--text-primary);font-size:1.05rem;font-weight:700}.app-header__crumb{min-width:0;overflow:hidden}.app-header__crumb .breadcrumb__current{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.breadcrumb{font-size:var(--font-sm);color:var(--text-secondary);align-items:center;gap:.4rem;display:flex}.breadcrumb__sep{color:var(--text-muted)}.breadcrumb__current{color:var(--text-primary);font-weight:600}.app-header__meta{align-items:center;gap:.6rem;display:flex}.app-header__badge{background:var(--primary-light);color:var(--primary);font-size:var(--font-xs);border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .65rem;font-weight:600;display:inline-flex}.sidebar-toggle,.sidebar__mobile-close,.sidebar-backdrop{display:none}.module-page{gap:var(--spacing-lg);flex-direction:column;min-height:0;display:flex}.module-page--fill{flex:1;min-height:0;overflow:hidden}.module-page__body{flex-direction:column;flex:1;min-height:0;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.page-header__title{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:1.35rem;font-weight:700}.page-header__description{font-size:var(--font-sm);color:var(--text-secondary);margin:.3rem 0 0}.page-header__actions{align-items:center;gap:var(--spacing-sm);flex-shrink:0;display:flex}.page-toolbar,.toolbar-row{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.toolbar-row__grow{flex:1;min-width:200px;max-width:360px}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:var(--spacing-lg)}.card--flush{padding:0;overflow:hidden}.card-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.btn{border-radius:var(--radius-md);font-size:var(--font-sm);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.4rem;padding:.5rem .9rem;font-weight:600;line-height:1.25;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;display:inline-flex}.btn:focus-visible{box-shadow:var(--ring);outline:none}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text-primary);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-soft);border-color:var(--text-muted)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-soft);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.btn-sm{font-size:var(--font-xs);padding:.375rem .7rem}.btn-icon{border-radius:var(--radius-sm);padding:.4rem}.btn__spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}.label{font-size:var(--font-sm);color:var(--text-primary);margin-bottom:.4rem;font-weight:600;display:block}.helper-text{font-size:var(--font-xs);color:var(--text-secondary);margin-top:.3rem;line-height:1.4}.helper-text--error{color:var(--danger)}.input,.select,textarea.input{border-radius:var(--radius-md);border:1px solid var(--border-strong);width:100%;font-size:var(--font-sm);color:var(--text-primary);background:var(--surface);outline:none;padding:.55rem .75rem;font-family:inherit;transition:border-color .15s,box-shadow .15s}.input::placeholder,textarea.input::placeholder{color:var(--text-muted)}.input:focus,.select:focus,textarea.input:focus{border-color:var(--primary);box-shadow:var(--ring)}.input--invalid,.input--invalid:focus{border-color:var(--danger);box-shadow:0 0 0 3px #dc262624}.input--search{padding-left:2.25rem}.input-wrap{position:relative}.input-wrap__icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.form-stack{gap:var(--spacing-md);flex-direction:column;display:flex}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-field--row{flex-direction:row;justify-content:space-between;align-items:center}.form-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.badge{text-transform:uppercase;letter-spacing:.02em;border:1px solid #0000;border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .55rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-light);color:var(--success);border-color:var(--success-border)}.badge-warning{background:var(--warning-light);color:var(--warning);border-color:var(--warning-border)}.badge-neutral{background:var(--surface-soft);color:var(--text-secondary);border-color:var(--border)}.badge-primary{background:var(--primary-light);color:var(--primary);border-color:var(--primary-border)}.badge__dot{background:currentColor;border-radius:50%;width:6px;height:6px}.table-wrap{flex:1;min-height:0;overflow:auto}.table{border-collapse:collapse;text-align:left;width:100%;font-size:var(--font-sm)}.table thead{background:var(--surface-soft);z-index:1;position:sticky;top:0}.table th{color:var(--text-secondary);font-weight:600;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-bottom:1px solid var(--border);padding:.7rem 1rem}.table td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:.8rem 1rem}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:var(--surface-soft)}.table tbody tr:last-child td{border-bottom:none}.table__cell-primary{font-weight:600}.table__cell-secondary{font-size:var(--font-xs);color:var(--text-secondary);margin-top:.125rem}.table__actions{text-align:right;white-space:nowrap}.table-card{flex-direction:column;min-height:0;display:flex}.table-card .table-wrap{flex:1}.icon-btn{border-radius:var(--radius-sm);color:var(--text-secondary);justify-content:center;align-items:center;padding:.4rem;transition:background .15s,color .15s;display:inline-flex}.icon-btn:hover{background:var(--surface-soft);color:var(--text-primary)}.icon-btn--primary{color:var(--primary)}.icon-btn--primary:hover{background:var(--primary-light)}.icon-btn--danger{color:var(--danger)}.icon-btn--danger:hover{background:var(--danger-light)}.icon-btn--purple{color:#7c3aed}.icon-btn--purple:hover{background:#f5f3ff}.icon-btn--cyan{color:#0891b2}.icon-btn--cyan:hover{background:#ecfeff}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.stat-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(210px,1fr));display:grid}.stat-card{background:var(--surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;gap:var(--spacing-md);display:flex}.stat-card__icon{border-radius:var(--radius-md);background:var(--primary-light);width:46px;height:46px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-card__icon--primary{background:var(--primary-light);color:var(--primary)}.stat-card__icon--success{background:var(--success-light);color:var(--success)}.stat-card__icon--warning{background:var(--warning-light);color:var(--warning)}.stat-card__icon--purple{color:#7c3aed;background:#f5f3ff}.stat-card__label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;font-weight:600}.stat-card__value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.tabs-bar{border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md);gap:.25rem;display:flex}.tab-btn{font-size:var(--font-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.55rem 1rem;font-weight:600;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text-primary)}.tab-btn--active{color:var(--primary);border-bottom-color:var(--primary)}.filter-pill{font-size:var(--font-xs);border:1px solid var(--border-strong);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.35rem .8rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.filter-pill:hover{border-color:var(--primary-border);color:var(--text-primary)}.filter-pill--active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.segmented{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface-soft);display:inline-flex;overflow:hidden}.segmented__btn{font-size:var(--font-xs);color:var(--text-secondary);border:none;border-right:1px solid var(--border-strong);background:0 0;padding:.4rem .8rem;font-weight:600}.segmented__btn:last-child{border-right:none}.segmented__btn--active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.chip-row{flex-wrap:wrap;gap:.4rem;display:flex}.chip{border:1px solid var(--border-strong);background:var(--surface);color:var(--text-primary);font-size:var(--font-xs);cursor:pointer;border-radius:999px;padding:.35rem .65rem;transition:background .15s,border-color .15s,color .15s}.chip:hover{border-color:var(--primary)}.chip--active{background:var(--primary);border-color:var(--primary);color:#fff}.role-chip{background:var(--primary-light);color:var(--primary);font-size:var(--font-sm);border-radius:999px;align-items:center;gap:.375rem;padding:.2rem .625rem;font-weight:500;display:inline-flex}.status-pill{font-size:var(--font-xs);border-radius:999px;padding:.2rem .55rem;font-weight:600}.status-pill--active{background:var(--success-light);color:var(--success)}.status-pill--inactive{background:var(--danger-light);color:var(--danger)}.mono-tag{color:var(--text-secondary);background:var(--surface-soft);border:1px solid var(--border);border-radius:4px;padding:.125rem .4rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem}.accordion{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.accordion__item+.accordion__item{border-top:1px solid var(--border)}.accordion__trigger{background:var(--surface-soft);width:100%;font-size:var(--font-sm);color:var(--text-primary);text-align:left;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-weight:600;display:flex}.accordion__body{background:var(--surface);padding:1rem}.drawer-overlay{z-index:100;background:#11182773;animation:.2s fadeIn;position:fixed;inset:0}.drawer-panel{width:min(var(--drawer-width), 100vw);background:var(--surface);box-shadow:var(--shadow-lg);z-index:101;flex-direction:column;animation:.25s slideIn;display:flex;position:fixed;top:0;bottom:0;right:0}.drawer-panel__header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.drawer-panel__title{font-size:var(--font-lg);margin:0;font-weight:600}.drawer-panel__subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin:.25rem 0 0}.drawer-panel__body{padding:var(--spacing-lg);flex:1;overflow-y:auto}.drawer-panel__footer{justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);background:var(--surface-soft);flex-shrink:0;display:flex}.modal-overlay{z-index:100;padding:var(--spacing-md);background:#11182780;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-height:90vh;animation:.18s scaleIn;display:flex}.modal-panel__header{justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.modal-panel__title{font-size:var(--font-lg);margin:0;font-weight:600}.modal-panel__body{padding:var(--spacing-lg);overflow-y:auto}.modal-panel__footer{justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);flex-shrink:0;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1.5rem}.empty-state__title{color:var(--text-primary);margin-top:.75rem;font-weight:600}.empty-state__desc{font-size:var(--font-sm);max-width:360px;margin:.25rem auto 0}.toast-container{z-index:200;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);font-size:var(--font-sm);box-shadow:var(--shadow-md);pointer-events:auto;background:var(--surface);border:1px solid var(--border);align-items:center;gap:.5rem;max-width:400px;padding:.7rem 1rem;font-weight:500;animation:.25s slideUp;display:flex}.toast__close{color:inherit;opacity:.6;margin-left:auto;display:inline-flex}.toast__close:hover{opacity:1}.toast--success{background:var(--success-light);color:#065f46;border-color:var(--success-border)}.toast--error{background:var(--danger-light);color:#991b1b;border-color:var(--danger-border)}.toast--info{background:var(--primary-light);color:var(--primary-hover);border-color:var(--primary-border)}.toast--warning{background:var(--warning-light);color:#92400e;border-color:var(--warning-border)}.alert{border-radius:var(--radius-md);font-size:var(--font-sm);margin-bottom:var(--spacing-md);padding:.75rem 1rem}.alert--error{background:var(--danger-light);color:#991b1b;border:1px solid var(--danger-border)}.alert--info{background:var(--primary-light);color:var(--primary-hover);border:1px solid var(--primary-border);line-height:1.5}.alert--warning{background:var(--warning-light);color:#92400e;border:1px solid var(--warning-border)}.alert--success{background:var(--success-light);color:#065f46;border:1px solid var(--success-border)}.master-detail-grid{flex:1;grid-template-columns:minmax(280px,340px) minmax(0,1fr);align-items:stretch;gap:1rem;min-height:0;display:grid}.master-detail-grid__panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:0;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.master-detail-grid__panel-head{border-bottom:1px solid var(--border);background:var(--surface-soft);flex-shrink:0;padding:.875rem 1rem}.master-detail-grid__panel-body{flex:1;min-height:0;padding:.75rem;overflow-y:auto}.master-detail-grid__detail-head{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;padding:1rem 1.25rem}.master-detail-grid__detail-body{background:var(--surface-soft);flex:1;min-height:0;padding:1.25rem;overflow-y:auto}.master-detail-grid__detail-actions{border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:.5rem;padding:.875rem 1.25rem;display:flex}.approval-inbox-item{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;width:100%;padding:.875rem 1rem;transition:border-color .15s,box-shadow .15s,background .15s}.approval-inbox-item:hover{border-color:var(--primary-border);background:var(--surface-soft)}.approval-inbox-item--active{border-color:var(--primary);background:var(--primary-light);box-shadow:0 4px 14px #4f46e51f}.section-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.section-card__head{border-bottom:1px solid var(--border);background:var(--surface-soft);padding:.85rem 1.1rem}.section-card__title{font-size:var(--font-md);color:var(--text-primary);margin:0;font-weight:600}.section-card__desc{font-size:var(--font-xs);color:var(--text-secondary);margin:.2rem 0 0}.section-card__body{padding:1.1rem}.report-card{gap:var(--spacing-md);flex-direction:column;display:flex}.report-card__header{justify-content:space-between;align-items:flex-start;display:flex}.report-card__icon{background:var(--primary-light);width:44px;height:44px;color:var(--primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.report-card__meta{border-top:1px solid var(--border);font-size:var(--font-sm);color:var(--text-secondary);flex-direction:column;gap:.5rem;padding-top:.75rem;display:flex}.login-page{background:radial-gradient(900px circle at 15% 10%, #4f46e514, transparent 45%), radial-gradient(700px circle at 85% 90%, #4f46e50f, transparent 45%), var(--background);min-height:100vh;padding:var(--spacing-md);justify-content:center;align-items:center;display:flex}.login-card{width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-card__header{text-align:center;margin-bottom:var(--spacing-xl)}.login-card__logo{background:var(--primary);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 1rem;font-size:1.5rem;font-weight:700;display:flex}.login-card__title{color:var(--text-primary);margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.login-card__subtitle{color:var(--text-secondary);font-size:var(--font-sm)}.workflow-chain{flex-direction:column;display:flex}.workflow-level{gap:.875rem;display:flex}.workflow-level__rail{flex-direction:column;flex-shrink:0;align-items:center;width:32px;display:flex}.workflow-level__dot{background:var(--primary);color:#fff;width:28px;height:28px;font-size:var(--font-xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.workflow-level__line{background:var(--border-strong);flex:1;width:2px;min-height:12px;margin:4px 0}.workflow-level__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);flex:1;margin-bottom:.75rem;padding:.875rem}.workflow-level__head{justify-content:space-between;align-items:center;margin-bottom:.625rem;display:flex}.workflow-level__label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.role-picker{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft);max-height:180px;overflow-y:auto}.role-picker__item{cursor:pointer;font-size:var(--font-sm);border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.role-picker__item:last-child{border-bottom:none}.role-picker__item:hover{background:var(--primary-light)}.role-picker__item--selected{background:var(--primary-light);font-weight:500}.role-combobox__backdrop{z-index:150;position:fixed;inset:0}.role-combobox__dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:151;margin-top:4px;position:absolute;top:100%;left:0;right:0}.workflow-section{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1.5rem}.workflow-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.workflow-section__title{font-size:var(--font-sm);margin:0 0 .375rem;font-weight:600}.workflow-section__hint{margin:0 0 .875rem}.workflow-checkbox{cursor:pointer;font-size:var(--font-sm);align-items:flex-start;gap:.625rem;display:flex}.workflow-checkbox input{width:16px;height:16px;accent-color:var(--primary);margin-top:2px}.workflow-alert{border-radius:var(--radius-md);font-size:var(--font-sm);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.625rem .875rem;display:flex}.workflow-alert--error{background:var(--danger-light);border:1px solid var(--danger-border);color:#991b1b}.workflow-alert--warn{background:var(--warning-light);border:1px solid var(--warning-border);color:#92400e}.workflow-summary{background:var(--primary-light);border:1px solid var(--primary-border);border-radius:var(--radius-lg);margin-bottom:1.25rem;padding:.875rem 1rem}.workflow-summary--compact{margin-bottom:0;padding:.75rem}.workflow-summary__title{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--primary);align-items:center;gap:.375rem;margin-bottom:.625rem;font-weight:700;display:flex}.workflow-summary__row{align-items:stretch;gap:.625rem;display:flex}.workflow-summary__block{border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffffd9;flex:1;min-width:0;padding:.625rem .75rem}.workflow-summary__label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;align-items:center;gap:.25rem;margin-bottom:.25rem;font-weight:700;display:flex}.workflow-summary__value{font-size:var(--font-sm);color:var(--text-primary);word-break:break-word;font-weight:600;line-height:1.45}.workflow-summary__arrow{color:var(--text-muted);flex-shrink:0;align-self:center}.submitter-picker__chips{flex-wrap:wrap;gap:.375rem;min-height:2rem;display:flex}.submitter-picker__empty{font-size:var(--font-sm);color:var(--text-muted);font-style:italic}.submitter-picker__chip{background:var(--primary-light);color:var(--primary-hover);border:1px solid var(--primary-border);font-size:var(--font-xs);border-radius:999px;align-items:center;gap:.25rem;padding:.25rem .5rem .25rem .625rem;font-weight:600;display:inline-flex}.submitter-picker__chip-remove{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.submitter-picker__chip-remove:hover{opacity:1}.submitter-picker__backdrop{z-index:150;position:fixed;inset:0}.submitter-picker__dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:260px;box-shadow:var(--shadow-md);z-index:151;margin-top:4px;padding:.5rem;position:absolute;top:100%;left:0}.workflow-mode-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.workflow-mode-card{border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:.375rem;padding:1rem;transition:border-color .15s,background .15s;display:flex}.workflow-mode-card strong{font-size:var(--font-sm);color:var(--text-primary)}.workflow-mode-card:hover{border-color:var(--primary-border);background:var(--surface-soft)}.workflow-mode-card--active{border-color:var(--primary);background:var(--primary-light)}.workflow-mode-card svg{color:var(--primary)}.workflow-loc-tabs{flex-wrap:wrap;gap:.375rem;display:flex}.workflow-loc-tab{border:1px solid var(--border);background:var(--surface);font-size:var(--font-xs);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.375rem .75rem;font-weight:600}.workflow-loc-tab--active{background:var(--primary-light);border-color:var(--primary-border);color:var(--primary-hover)}.vpc-groups{flex-direction:column;gap:.75rem;display:flex}.vpc-group{padding:0;overflow:hidden}.vpc-group__header{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);background:0 0;border:none;align-items:center;gap:.5rem;padding:.875rem 1rem;display:flex}.vpc-group__title{font-weight:600;font-size:var(--font-md);flex:1}.vpc-group__actions{gap:.25rem;display:flex}.vpc-group__body{flex-direction:column;gap:.625rem;padding:0 1rem 1rem;display:flex}.vpc-empty{color:var(--text-secondary);font-size:var(--font-sm);margin:0;padding:.5rem 0}.vpc-cat-card,.vpc-field-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft);padding:.875rem}.vpc-cat-card__head,.vpc-field-card__head{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.vpc-cat-card__chips{flex-wrap:wrap;gap:.375rem;margin-bottom:.625rem;display:flex}.vpc-cat-card__actions{flex-wrap:wrap;gap:.375rem;display:flex}.vpc-section-title{font-size:var(--font-xs);letter-spacing:.04em;color:var(--text-secondary);margin:1.25rem 0 .75rem;font-weight:700}.perm-toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.perm-toggle-row:last-child{border-bottom:none}.emp-picker-list{flex-direction:column;gap:.35rem;max-height:280px;margin-top:.75rem;display:flex;overflow-y:auto}.emp-picker-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;padding:.65rem .75rem;display:flex}.emp-picker-item:hover{border-color:var(--primary);background:var(--primary-light)}.emp-picker-item span{color:var(--text-secondary);font-size:.8rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-shell-nav{flex-shrink:0;height:100%;display:flex}.app-rail{border-right:1px solid var(--border);background:#f5f7fe;flex-direction:column;flex-shrink:0;align-items:center;gap:.5rem;width:86px;padding:.6rem .45rem;display:flex}.app-rail__toggle{border-radius:var(--radius-md);width:42px;height:42px;color:var(--primary);background:var(--primary-light);flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.app-rail__toggle:hover{background:var(--primary-border)}.app-rail__groups{flex-direction:column;flex:1;align-items:stretch;gap:.35rem;width:100%;padding-top:.35rem;display:flex;overflow-y:auto}.rail-item{border-radius:var(--radius-lg);color:var(--text-secondary);border:1px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:.7rem .25rem;transition:background .15s,color .15s,box-shadow .15s,border-color .15s;display:flex}.rail-item:hover{color:var(--text-primary);background:#ffffffb3}.rail-item--active{background:var(--surface);color:var(--primary);border-color:var(--border);box-shadow:var(--shadow-sm)}.rail-item__icon{justify-content:center;align-items:center;display:flex}.rail-item--active .rail-item__icon{color:var(--primary)}.rail-item__label{text-align:center;font-size:.63rem;font-weight:600;line-height:1.15}.rail-item--active .rail-item__label{font-weight:700}.app-rail__bottom{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:.5rem;width:100%;padding-top:.5rem;display:flex}.app-subnav{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:236px;min-width:0;transition:width .18s;display:flex}.app-subnav__head{flex-shrink:0;align-items:center;gap:.55rem;padding:.95rem 1rem .6rem;display:flex}.app-subnav__head-icon{border-radius:var(--radius-md);background:var(--primary-light);width:30px;height:30px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.app-subnav__head-title{font-size:var(--font-md);color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.app-subnav__list{flex-direction:column;flex:1;gap:2px;padding:0 .6rem .85rem;list-style:none;display:flex;overflow-y:auto}.app-subnav .nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.app-shell-nav{position:relative}.app-subnav--collapsed{width:72px}.app-subnav--collapsed .app-subnav__head-title,.app-subnav--collapsed .nav-label{display:none}.app-subnav--collapsed .app-subnav__head{justify-content:center;padding:.75rem 0}.app-subnav--collapsed .app-subnav__list{align-items:center;gap:7px;padding:.3rem 0 .85rem}.app-subnav--collapsed .nav-item{border-radius:var(--radius-md);justify-content:center;width:44px;height:44px;padding:0}.app-subnav--collapsed .nav-item--active:before{display:none}.app-shell-nav:hover .app-subnav--collapsed{z-index:60;width:236px;box-shadow:var(--shadow-lg);border-right:1px solid var(--border);animation:.16s flyoutIn;position:absolute;top:0;bottom:0;left:86px}.app-shell-nav:hover .app-subnav--collapsed .app-subnav__head-title,.app-shell-nav:hover .app-subnav--collapsed .nav-label{display:revert}.app-shell-nav:hover .app-subnav--collapsed .app-subnav__head{justify-content:flex-start;padding:.95rem 1rem .6rem}.app-shell-nav:hover .app-subnav--collapsed .app-subnav__list{align-items:stretch;gap:2px;padding:0 .6rem .85rem}.app-shell-nav:hover .app-subnav--collapsed .nav-item{justify-content:flex-start;width:auto;height:auto;padding:.55rem .75rem}.app-shell-nav:hover .app-subnav--collapsed .nav-item--active:before{display:block}@keyframes flyoutIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@media (width<=1200px){.master-detail-grid{grid-template-columns:minmax(260px,300px) minmax(0,1fr)}}@media (width<=1024px){.app-subnav{width:72px}.app-subnav__head-title,.app-subnav .nav-label{display:none}.app-subnav__head{justify-content:center;padding:.75rem 0}.app-subnav__list{align-items:center;gap:7px}.app-subnav .nav-item{justify-content:center;width:44px;height:44px;padding:0}.app-subnav .nav-item--active:before{display:none}.master-detail-grid{grid-template-rows:minmax(200px,30vh) minmax(0,1fr);grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.workflow-mode-grid{grid-template-columns:1fr}}@media (width<=768px){.page-content{padding:.85rem}.page-header,.page-toolbar{flex-direction:column;align-items:stretch}.page-toolbar>*{width:100%}.stat-grid,.card-grid{grid-template-columns:1fr}.modal-panel{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:100vw!important}.drawer-panel{width:100vw}.app-header__brand-title{display:none}.app-rail{width:62px;padding:.5rem .3rem}.rail-item{padding:.55rem .15rem}.rail-item__label{display:none}.app-subnav{width:62px}}.page-content>*{min-width:0;max-width:100%}.card,.table-card,[class*=grid]{min-width:0}
