@charset "UTF-8";:root{--op-color-primary: #2563eb;--op-color-primary-hover: #1d4ed8;--op-color-primary-active: #1e40af;--op-color-primary-subtle: #eff4ff;--op-color-primary-border: #bfd4fe;--op-color-vendor-accent: #0e7c86;--op-color-vendor-accent-subtle: #e6f4f5;--op-status-submitted: #2563eb;--op-status-submitted-bg: #eff4ff;--op-status-processing: #b06a00;--op-status-processing-bg: #fdf2e0;--op-status-approved: #1e7a3c;--op-status-approved-bg: #e9f6ed;--op-status-rejected: #c02b3e;--op-status-rejected-bg: #fbe9eb;--op-status-paid: #0e7c86;--op-status-paid-bg: #e6f4f5;--op-color-bg: #f6f7f9;--op-color-surface: #ffffff;--op-color-surface-alt: #fafbfc;--op-color-border: #e2e5ea;--op-color-border-strong: #c9ced6;--op-color-text: #10131a;--op-color-text-muted: #5b6472;--op-color-text-faint: #8a93a1;--op-color-disabled: #b7bdc7;--op-color-danger: #c02b3e;--op-color-danger-bg: #fbe9eb;--op-color-warning: #b06a00;--op-color-warning-bg: #fdf2e0;--op-color-success: #1e7a3c;--op-color-success-bg: #e9f6ed;--op-color-info: #2563eb;--op-color-info-bg: #eff4ff;--op-font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--op-font-size-xs: .75rem;--op-font-size-sm: .8125rem;--op-font-size-base: .9375rem;--op-font-size-md: 1rem;--op-font-size-lg: 1.125rem;--op-font-size-xl: 1.5rem;--op-font-size-2xl: 1.875rem;--op-font-weight-regular: 400;--op-font-weight-medium: 500;--op-font-weight-semibold: 600;--op-font-weight-bold: 700;--op-radius-sm: 4px;--op-radius: 8px;--op-radius-lg: 12px;--op-radius-full: 999px;--op-shadow-sm: 0 1px 2px rgba(16, 19, 26, .06);--op-shadow-md: 0 4px 12px rgba(16, 19, 26, .08);--op-shadow-lg: 0 12px 32px rgba(16, 19, 26, .14);--op-sidebar-width: 248px;--op-header-height: 64px;--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-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);color:var(--op-color-text);background:var(--op-color-bg);-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--op-font-weight-semibold);color:var(--op-color-text)}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-base)}::selection{background:var(--op-color-primary-subtle)}.op-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--op-space-2);font-size:var(--op-font-size-sm);font-weight:var(--op-font-weight-semibold);border-radius:var(--op-radius);padding:10px 16px;border:1px solid transparent;cursor:pointer;transition:background-color var(--op-transition-fast),border-color var(--op-transition-fast),color var(--op-transition-fast)}.op-btn:disabled{cursor:not-allowed;opacity:.55}.op-btn--primary{background:var(--op-color-primary);color:#fff}.op-btn--primary:hover:not(:disabled){background:var(--op-color-primary-hover)}.op-btn--secondary{background:var(--op-color-surface);border-color:var(--op-color-border-strong);color:var(--op-color-text)}.op-btn--secondary:hover:not(:disabled){border-color:var(--op-color-primary);color:var(--op-color-primary)}.op-btn--danger{background:var(--op-color-surface);border-color:var(--op-color-danger);color:var(--op-color-danger)}.op-btn--danger:hover:not(:disabled){background:var(--op-color-danger-bg)}.op-btn--ghost{background:transparent;color:var(--op-color-text-muted)}.op-btn--ghost:hover:not(:disabled){background:var(--op-color-surface-alt);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%;border:1px solid var(--op-color-border-strong);border-radius:var(--op-radius);padding:10px 12px;background:var(--op-color-surface);color:var(--op-color-text)}.op-input:focus{outline:none;border-color:var(--op-color-primary);box-shadow:0 0 0 3px var(--op-color-primary-subtle)}.op-label{display:block;font-size:var(--op-font-size-sm);font-weight:var(--op-font-weight-medium);color:var(--op-color-text-muted);margin-bottom:var(--op-space-2)}.op-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--op-radius-full);font-size:var(--op-font-size-xs);font-weight:var(--op-font-weight-semibold);white-space:nowrap}.op-badge--submitted{color:var(--op-status-submitted);background:var(--op-status-submitted-bg)}.op-badge--processing{color:var(--op-status-processing);background:var(--op-status-processing-bg)}.op-badge--approved{color:var(--op-status-approved);background:var(--op-status-approved-bg)}.op-badge--rejected{color:var(--op-status-rejected);background:var(--op-status-rejected-bg)}.op-badge--paid{color:var(--op-status-paid);background:var(--op-status-paid-bg)}.op-badge--default{color:var(--op-color-text-muted);background:var(--op-color-surface-alt)}.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}.op-table-state__icon{font-size:28px}.op-table-state--error{color:var(--op-color-danger)}.op-page{display:flex;flex-direction:column;gap:var(--op-space-5);max-width:1200px}.op-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--op-space-4);flex-wrap:wrap}.op-page__header h1{font-size:var(--op-font-size-2xl)}.op-page__subtitle{color:var(--op-color-text-muted);margin-top:var(--op-space-1)}.op-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,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)}.op-kpi__label{font-size:var(--op-font-size-xs);color:var(--op-color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:var(--op-font-weight-medium)}.op-kpi__value{font-size:var(--op-font-size-2xl);font-weight:var(--op-font-weight-bold)}.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)}.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{text-align:left;padding:var(--op-space-3) var(--op-space-3);color:var(--op-color-text-muted);font-weight:var(--op-font-weight-medium);font-size:var(--op-font-size-xs);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--op-color-border);white-space:nowrap}.op-table tbody td{padding:var(--op-space-3) var(--op-space-3);border-bottom:1px solid var(--op-color-border);vertical-align:middle}.op-table tbody tr{cursor:default;transition:background-color var(--op-transition-fast)}.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-surface-alt)}.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);font-size:var(--op-font-size-sm)}.op-notice--warning{background:var(--op-color-warning-bg);color:var(--op-color-warning)}.op-notice--error{background:var(--op-color-danger-bg);color:var(--op-color-danger)}.op-notice--info{background:var(--op-color-info-bg);color:var(--op-color-info)}.op-notice--success{background:var(--op-color-success-bg);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:6px 14px 6px 6px;border-radius:var(--op-radius-full);background:var(--op-color-surface-alt);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)}.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:2px 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);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:2fr 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:.03em}.op-dl dd{margin:0;font-size:var(--op-font-size-base);font-weight:var(--op-font-weight-medium)}.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:5px;top:14px;bottom:0;width:2px;background:var(--op-color-border)}.op-timeline__dot{width:12px;height:12px;border-radius:50%;background:var(--op-color-primary);margin-top:4px;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);color:var(--op-color-success);display:flex;align-items:center;justify-content:center;font-size:28px;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-alt);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:SF Mono,Consolas,monospace;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-alt);border-radius:var(--op-radius-lg);padding:var(--op-space-3) var(--op-space-4);font-size:var(--op-font-size-sm)}.op-thread__message--mine .op-thread__bubble{background:var(--op-color-primary-subtle)}.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-4) 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)}
