@charset "UTF-8";:root{--op-color-primary: #2563eb;--op-color-primary-hover: #1d4ed8;--op-color-primary-active: #1e40af;--op-color-primary-subtle: #eff6ff;--op-color-primary-border: #bfdbfe;--op-color-vendor-accent: #0f766e;--op-color-vendor-accent-hover: #115e59;--op-color-vendor-accent-subtle: #f0fdfa;--op-sidebar-bg: #1e293b;--op-sidebar-bg-deep: #0f172a;--op-sidebar-border: rgba(148, 163, 184, .16);--op-sidebar-text: #cbd5e1;--op-sidebar-text-muted: #7d8ba1;--op-sidebar-hover-bg: rgba(148, 163, 184, .1);--op-sidebar-active-bg: rgba(37, 99, 235, .22);--op-sidebar-active-text: #ffffff;--op-sidebar-accent: #60a5fa;--op-sidebar-vendor-accent: #5eead4;--op-status-submitted: #1d4ed8;--op-status-submitted-bg: #eff6ff;--op-status-submitted-border: #bfdbfe;--op-status-processing: #92400e;--op-status-processing-bg: #fffbeb;--op-status-processing-border: #fde68a;--op-status-approved: #166534;--op-status-approved-bg: #f0fdf4;--op-status-approved-border: #bbf7d0;--op-status-rejected: #b91c1c;--op-status-rejected-bg: #fef2f2;--op-status-rejected-border: #fecaca;--op-status-paid: #0f766e;--op-status-paid-bg: #f0fdfa;--op-status-paid-border: #99f6e4;--op-color-bg: #f8fafc;--op-color-surface: #ffffff;--op-color-surface-alt: #f8fafc;--op-color-surface-sunken: #f1f5f9;--op-color-border: #e2e8f0;--op-color-border-strong: #cbd5e1;--op-color-text: #0f172a;--op-color-text-muted: #475569;--op-color-text-faint: #94a3b8;--op-color-disabled: #cbd5e1;--op-color-danger: #b91c1c;--op-color-danger-bg: #fef2f2;--op-color-danger-border: #fecaca;--op-color-warning: #92400e;--op-color-warning-bg: #fffbeb;--op-color-warning-border: #fde68a;--op-color-success: #166534;--op-color-success-bg: #f0fdf4;--op-color-success-border: #bbf7d0;--op-color-info: #1d4ed8;--op-color-info-bg: #eff6ff;--op-color-info-border: #bfdbfe;--op-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;--op-font-family-mono: ui-monospace, "SF Mono", "Cascadia Mono", Consolas, Menlo, monospace;--op-font-size-xs: .6875rem;--op-font-size-sm: .8125rem;--op-font-size-base: .875rem;--op-font-size-md: .9375rem;--op-font-size-lg: 1rem;--op-font-size-xl: 1.25rem;--op-font-size-2xl: 1.5rem;--op-font-weight-regular: 400;--op-font-weight-medium: 500;--op-font-weight-semibold: 600;--op-font-weight-bold: 700;--op-radius-sm: 3px;--op-radius: 6px;--op-radius-lg: 8px;--op-radius-full: 999px;--op-shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--op-shadow-md: 0 2px 6px rgba(15, 23, 42, .06);--op-shadow-lg: 0 10px 24px rgba(15, 23, 42, .12);--op-sidebar-width: 250px;--op-header-height: 52px;--op-space-1: 4px;--op-space-2: 8px;--op-space-3: 12px;--op-space-4: 16px;--op-space-5: 24px;--op-space-6: 32px;--op-space-7: 48px;--op-control-height: 36px;--op-focus-ring: 0 0 0 3px rgba(37, 99, 235, .18);--op-transition-fast: .12s ease;--op-transition: .18s ease}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{font-family:var(--op-font-family);font-size:var(--op-font-size-base);line-height:1.45;color:var(--op-color-text);background:var(--op-color-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--op-font-weight-semibold);color:var(--op-color-text);letter-spacing:-.01em}p{margin:0}a{color:var(--op-color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:var(--op-font-size-sm)}::selection{background:var(--op-color-primary-subtle)}.op-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--op-space-2);min-height:var(--op-control-height);font-size:var(--op-font-size-sm);font-weight:var(--op-font-weight-medium);line-height:1.2;border-radius:var(--op-radius);padding:7px 14px;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background-color var(--op-transition-fast),border-color var(--op-transition-fast),box-shadow var(--op-transition-fast),color var(--op-transition-fast)}.op-btn:focus-visible{outline:none;box-shadow:var(--op-focus-ring)}.op-btn:disabled{cursor:not-allowed;opacity:.55}.op-btn--primary{background:var(--op-color-primary);border-color:var(--op-color-primary);color:#fff;font-weight:var(--op-font-weight-semibold)}.op-btn--primary:hover:not(:disabled){background:var(--op-color-primary-hover);border-color:var(--op-color-primary-hover)}.op-btn--primary:active:not(:disabled){background:var(--op-color-primary-active)}.op-btn--secondary{background:var(--op-color-surface);border-color:var(--op-color-border-strong);color:var(--op-color-text);box-shadow:var(--op-shadow-sm)}.op-btn--secondary:hover:not(:disabled){background:var(--op-color-surface-alt);border-color:var(--op-color-text-faint);text-decoration:none}.op-btn--danger{background:var(--op-color-surface);border-color:var(--op-color-danger-border);color:var(--op-color-danger)}.op-btn--danger:hover:not(:disabled){background:var(--op-color-danger-bg);border-color:var(--op-color-danger)}.op-btn--ghost{background:transparent;color:var(--op-color-text-muted)}.op-btn--ghost:hover:not(:disabled){background:var(--op-color-surface-sunken);color:var(--op-color-text)}.op-card{background:var(--op-color-surface);border:1px solid var(--op-color-border);border-radius:var(--op-radius-lg);box-shadow:var(--op-shadow-sm)}.op-input{width:100%;min-height:var(--op-control-height);border:1px solid var(--op-color-border-strong);border-radius:var(--op-radius);padding:7px 10px;background:var(--op-color-surface);color:var(--op-color-text);transition:border-color var(--op-transition-fast),box-shadow var(--op-transition-fast)}.op-input::placeholder{color:var(--op-color-text-faint)}.op-input:focus{outline:none;border-color:var(--op-color-primary);box-shadow:var(--op-focus-ring)}.op-input:disabled{background:var(--op-color-surface-sunken);color:var(--op-color-text-muted);cursor:not-allowed}.op-label{display:block;font-size:var(--op-font-size-xs);font-weight:var(--op-font-weight-semibold);color:var(--op-color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--op-space-2)}.op-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--op-radius-sm);border:1px solid transparent;font-size:var(--op-font-size-xs);font-weight:var(--op-font-weight-semibold);letter-spacing:.02em;text-transform:uppercase;line-height:1.6;white-space:nowrap}.op-badge--submitted{color:var(--op-status-submitted);background:var(--op-status-submitted-bg);border-color:var(--op-status-submitted-border)}.op-badge--processing{color:var(--op-status-processing);background:var(--op-status-processing-bg);border-color:var(--op-status-processing-border)}.op-badge--approved{color:var(--op-status-approved);background:var(--op-status-approved-bg);border-color:var(--op-status-approved-border)}.op-badge--rejected{color:var(--op-status-rejected);background:var(--op-status-rejected-bg);border-color:var(--op-status-rejected-border)}.op-badge--paid{color:var(--op-status-paid);background:var(--op-status-paid-bg);border-color:var(--op-status-paid-border)}.op-badge--default{color:var(--op-color-text-muted);background:var(--op-color-surface-sunken);border-color:var(--op-color-border)}.op-table-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--op-space-3);padding:var(--op-space-7) var(--op-space-4);color:var(--op-color-text-muted);text-align:center;font-size:var(--op-font-size-sm)}.op-table-state__icon{font-size:24px;color:var(--op-color-text-faint)}.op-table-state--error{color:var(--op-color-danger)}.op-page{display:flex;flex-direction:column;gap:var(--op-space-5);width:100%;min-height:100%}.op-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--op-space-4);flex-wrap:wrap;padding-bottom:var(--op-space-4);border-bottom:1px solid var(--op-color-border)}.op-page__header h1{font-size:var(--op-font-size-xl);font-weight:var(--op-font-weight-semibold);line-height:1.3}.op-page__subtitle{color:var(--op-color-text-muted);font-size:var(--op-font-size-sm);margin-top:var(--op-space-1)}.op-page__header>div:last-child:not(:first-child),.op-page__actions{display:flex;align-items:center;gap:var(--op-space-3)}.op-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--op-space-4)}.op-kpi{display:flex;flex-direction:column;gap:var(--op-space-2);padding:var(--op-space-4) var(--op-space-5);border-radius:var(--op-radius-lg)}.op-kpi__label{font-size:var(--op-font-size-xs);color:var(--op-color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--op-font-weight-semibold)}.op-kpi__value{font-size:var(--op-font-size-2xl);font-weight:var(--op-font-weight-semibold);font-variant-numeric:tabular-nums;line-height:1.15;letter-spacing:-.02em}.op-panel{padding:var(--op-space-5);display:flex;flex-direction:column;gap:var(--op-space-4)}.op-panel__header{display:flex;align-items:center;justify-content:space-between;gap:var(--op-space-3);flex-wrap:wrap}.op-panel__header h2{font-size:var(--op-font-size-lg);font-weight:var(--op-font-weight-semibold)}.op-panel h2{font-size:var(--op-font-size-lg)}.op-panel__toolbar{display:flex;align-items:center;gap:var(--op-space-3);flex-wrap:wrap}.op-table{width:100%;border-collapse:collapse;font-size:var(--op-font-size-sm)}.op-table thead th{position:sticky;top:0;z-index:1;text-align:left;padding:var(--op-space-2) var(--op-space-3);background:var(--op-color-surface);color:var(--op-color-text-muted);font-weight:var(--op-font-weight-semibold);font-size:var(--op-font-size-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--op-color-border-strong);box-shadow:inset 0 -1px 0 var(--op-color-border-strong);white-space:nowrap}.op-table tbody td{padding:var(--op-space-2) var(--op-space-3);border-bottom:1px solid var(--op-color-border);vertical-align:middle;font-variant-numeric:tabular-nums;line-height:1.4}.op-table tbody tr:last-child td{border-bottom:none}.op-table tbody tr{cursor:default;transition:background-color var(--op-transition-fast)}.op-table tbody tr:hover{background:var(--op-color-surface-alt)}.op-table tbody tr[routerLink],.op-table tbody tr.op-table__row--clickable{cursor:pointer}.op-table tbody tr[routerLink]:hover,.op-table tbody tr.op-table__row--clickable:hover{background:var(--op-color-primary-subtle)}.op-table th.op-num,.op-table td.op-num,.op-table th.op-table__num,.op-table td.op-table__num{text-align:right}.op-notice{display:flex;align-items:center;justify-content:space-between;gap:var(--op-space-3);padding:var(--op-space-3) var(--op-space-4);border-radius:var(--op-radius);border:1px solid transparent;font-size:var(--op-font-size-sm)}.op-notice--warning{background:var(--op-color-warning-bg);border-color:var(--op-color-warning-border);color:var(--op-color-warning)}.op-notice--error{background:var(--op-color-danger-bg);border-color:var(--op-color-danger-border);color:var(--op-color-danger)}.op-notice--info{background:var(--op-color-info-bg);border-color:var(--op-color-info-border);color:var(--op-color-info)}.op-notice--success{background:var(--op-color-success-bg);border-color:var(--op-color-success-border);color:var(--op-color-success)}.op-field{display:flex;flex-direction:column;gap:var(--op-space-2)}.op-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--op-space-4)}.op-steps{display:flex;align-items:center;gap:var(--op-space-2);margin-bottom:var(--op-space-2)}.op-step{display:flex;align-items:center;gap:var(--op-space-2);padding:5px 12px 5px 5px;border-radius:var(--op-radius-full);background:var(--op-color-surface-sunken);color:var(--op-color-text-muted);font-size:var(--op-font-size-sm);font-weight:var(--op-font-weight-medium)}.op-step__num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--op-color-border);color:var(--op-color-text);font-size:var(--op-font-size-xs);font-weight:var(--op-font-weight-semibold);font-variant-numeric:tabular-nums}.op-step--active{background:var(--op-color-primary-subtle);color:var(--op-color-primary)}.op-step--active .op-step__num{background:var(--op-color-primary);color:#fff}.op-step--done .op-step__num{background:var(--op-color-success);color:#fff}.op-dropzone{border:1.5px dashed var(--op-color-border-strong);border-radius:var(--op-radius-lg);padding:var(--op-space-7) var(--op-space-4);text-align:center;color:var(--op-color-text-muted);background:var(--op-color-surface-alt);transition:border-color var(--op-transition-fast),background-color var(--op-transition-fast)}.op-dropzone--active{border-color:var(--op-color-primary);background:var(--op-color-primary-subtle)}.op-breadcrumb{display:inline-block;font-size:var(--op-font-size-sm);color:var(--op-color-text-muted);margin-bottom:var(--op-space-2)}.op-detail-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:var(--op-space-5);align-items:start}@media(max-width:860px){.op-detail-grid{grid-template-columns:1fr}}.op-dl{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--op-space-4);margin:0 0 var(--op-space-2)}.op-dl>div{display:flex;flex-direction:column;gap:2px}.op-dl dt{font-size:var(--op-font-size-xs);color:var(--op-color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--op-font-weight-medium)}.op-dl dd{margin:0;font-size:var(--op-font-size-base);font-weight:var(--op-font-weight-medium);font-variant-numeric:tabular-nums}.op-timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.op-timeline__item{display:flex;gap:var(--op-space-3);padding-bottom:var(--op-space-5);position:relative}.op-timeline__item:not(:last-child):before{content:"";position:absolute;left:4px;top:14px;bottom:0;width:1.5px;background:var(--op-color-border)}.op-timeline__dot{width:10px;height:10px;border-radius:50%;background:var(--op-color-primary);box-shadow:0 0 0 3px var(--op-color-primary-subtle);margin-top:5px;flex-shrink:0}.op-timeline__label{font-weight:var(--op-font-weight-semibold);font-size:var(--op-font-size-sm)}.op-timeline__meta{font-size:var(--op-font-size-xs);color:var(--op-color-text-muted)}.op-timeline__note{margin-top:var(--op-space-1);font-size:var(--op-font-size-sm);color:var(--op-color-text-muted)}.op-form-actions{display:flex;justify-content:flex-end;gap:var(--op-space-3);margin-top:var(--op-space-2)}.op-form-actions--full{grid-column:1/-1}.op-dropzone__file{margin-top:var(--op-space-3);font-size:var(--op-font-size-sm);font-weight:var(--op-font-weight-medium);color:var(--op-color-text)}.op-page--center{min-height:calc(100vh - var(--op-header-height) - var(--op-space-6) * 2);display:flex;align-items:center;justify-content:center}.op-success-card{max-width:480px;padding:var(--op-space-7) var(--op-space-6);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--op-space-3)}.op-success-card__icon{width:56px;height:56px;border-radius:50%;background:var(--op-color-success-bg);border:1px solid var(--op-color-success-border);color:var(--op-color-success);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:var(--op-space-2)}.op-success-card__qid{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--op-color-surface-sunken);border:1px solid var(--op-color-border);border-radius:var(--op-radius);padding:var(--op-space-3) var(--op-space-5);margin:var(--op-space-2) 0}.op-success-card__qid-value{font-size:var(--op-font-size-lg);font-weight:var(--op-font-weight-bold);font-family:var(--op-font-family-mono);color:var(--op-color-primary)}.op-form-actions--center{justify-content:center}.op-thread{display:flex;flex-direction:column;gap:var(--op-space-4);max-height:480px;overflow-y:auto;padding:var(--op-space-2)}.op-thread__message{display:flex;flex-direction:column;gap:4px;max-width:70%}.op-thread__message--mine{align-self:flex-end;align-items:flex-end}.op-thread__author{font-size:var(--op-font-size-xs);color:var(--op-color-text-muted);font-weight:var(--op-font-weight-medium)}.op-thread__bubble{background:var(--op-color-surface-sunken);border:1px solid var(--op-color-border);border-radius:var(--op-radius-lg);padding:var(--op-space-2) var(--op-space-3);font-size:var(--op-font-size-sm)}.op-thread__message--mine .op-thread__bubble{background:var(--op-color-primary-subtle);border-color:var(--op-color-primary-border)}.op-thread__time{font-size:var(--op-font-size-xs);color:var(--op-color-text-faint)}.op-thread__composer{display:flex;gap:var(--op-space-3);border-top:1px solid var(--op-color-border);padding-top:var(--op-space-4)}.op-thread__composer .op-input{flex:1}.op-notif-list{display:flex;flex-direction:column}.op-notif{display:flex;align-items:flex-start;gap:var(--op-space-3);padding:var(--op-space-3) var(--op-space-2);border:none;border-bottom:1px solid var(--op-color-border);background:transparent;text-align:left;cursor:pointer;width:100%;font-family:inherit}.op-notif:last-child{border-bottom:none}.op-notif:hover{background:var(--op-color-surface-alt)}.op-notif__dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0;background:transparent}.op-notif--unread .op-notif__dot{background:var(--op-color-primary)}.op-notif__body{display:flex;flex-direction:column;gap:2px}.op-notif__title{font-weight:var(--op-font-weight-semibold);font-size:var(--op-font-size-sm)}.op-notif--unread .op-notif__title{color:var(--op-color-text)}.op-notif__text{font-size:var(--op-font-size-sm);color:var(--op-color-text-muted)}.op-notif__time{font-size:var(--op-font-size-xs);color:var(--op-color-text-faint)}.op-quicklinks{display:flex;flex-wrap:wrap;gap:var(--op-space-3)}
