:root{--bg-page: #F8F7F4;--bg-primary: #FFFFFF;--bg-secondary: #F5F4F0;--bg-tertiary: #EEEDEA;--text-primary: #1A1A18;--text-secondary: #5A5955;--text-muted: #9A9890;--border: #E8E6E0;--border-focus: #1A4A7A;--green: #2D6A2D;--green-bg: #F2F9F2;--green-border: #A0C8A0;--amber: #B45309;--amber-bg: #FFFBF0;--amber-border: #E8C87A;--red: #C0392B;--red-bg: #FDF2F0;--red-border: #E8A090;--blue: #1A4A7A;--blue-bg: #F0F5FB;--blue-border: #90B4D8;--brand: #0D2E4E;--brand-light: #E6F1FB;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-ui: -apple-system, "PingFang SC", "Helvetica Neue", Arial, sans-serif;--font-mono: "Courier New", Courier, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-ui);background:var(--bg-page);color:var(--text-primary);font-size:14px;line-height:1.5}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted);font-size:14px}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);z-index:9999;max-width:360px}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:13px;border:.5px solid var(--border);background:var(--bg-primary);color:var(--text-primary);box-shadow:0 2px 8px #00000014}.toast--error{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.toast--success{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}.toast--warning{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}.pending-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:var(--space-8);text-align:center;gap:var(--space-4);max-width:480px;margin:0 auto}.pending-screen__icon{font-size:48px}.pending-screen__title{font-size:20px;font-weight:500;color:var(--text-primary)}.pending-screen__desc{font-size:14px;color:var(--text-secondary);line-height:1.6}.pending-screen__sub{font-size:13px;color:var(--text-muted);line-height:1.6}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:var(--space-4)}.auth-card{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-8);width:100%;max-width:400px}.auth-card--wide{max-width:520px}.auth-logo{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-8)}.auth-logo__mark{width:32px;height:32px;background:var(--brand);color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500}.auth-logo__name{font-size:16px;font-weight:500;color:var(--brand)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-footer{text-align:center;margin-top:var(--space-4);font-size:13px;color:var(--text-muted)}.auth-footer a{color:var(--blue);text-decoration:none}.auth-success{text-align:center;padding:var(--space-4) 0}.auth-success__icon{font-size:40px;margin-bottom:var(--space-4)}.auth-success h2{font-size:18px;font-weight:500;margin-bottom:var(--space-3)}.auth-success p{color:var(--text-secondary);margin-bottom:var(--space-2);font-size:13px}.auth-success__en{color:var(--text-muted);font-size:12px;margin-bottom:var(--space-6)}.field{display:flex;flex-direction:column;gap:var(--space-1)}.field__label{font-size:12px;font-weight:500;color:var(--text-secondary)}.field__input{height:44px;padding:0 var(--space-3);border:.5px solid var(--border);border-radius:var(--radius-md);font-size:16px;font-family:var(--font-ui);background:var(--bg-primary);color:var(--text-primary);width:100%}.field__input:focus{outline:none;border-color:var(--border-focus);border-width:1px}.field__hint{font-size:11px;color:var(--text-muted)}.field__select{height:44px;padding:0 var(--space-3);border:.5px solid var(--border);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-ui);background:var(--bg-primary);color:var(--text-primary)}.field-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:44px;padding:0 var(--space-6);border-radius:var(--radius-md);font-size:14px;font-weight:500;font-family:var(--font-ui);border:none;cursor:pointer}.btn--primary{background:var(--brand);color:#fff}.btn--primary:hover{opacity:.9}.btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border:.5px solid var(--border)}.btn--danger{background:var(--red-bg);color:var(--red);border:.5px solid var(--red-border)}.btn--full{width:100%}.btn--sm{height:32px;padding:0 var(--space-3);font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.app-shell{display:grid;grid-template-rows:44px 1fr;grid-template-columns:200px 1fr;min-height:100vh}.app-shell__body{display:contents}.app-shell__main{grid-column:2;grid-row:2;overflow-y:auto;background:var(--bg-page)}.topbar{grid-column:1 / -1;grid-row:1;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);background:var(--brand);border-bottom:.5px solid var(--border);height:44px}.topbar__left{display:flex;align-items:center;gap:var(--space-3)}.topbar__logo{display:flex;align-items:center;gap:var(--space-2)}.topbar__logo-mark{width:24px;height:24px;background:#fff3;color:#fff;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500}.topbar__logo-name{font-size:14px;font-weight:500;color:#fff}.topbar__right{display:flex;align-items:center;gap:var(--space-3)}.topbar__lang{background:#ffffff26;color:#fff;border:none;border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-size:12px;cursor:pointer}.topbar__bell{background:none;border:none;color:#fff;font-size:16px;cursor:pointer}.topbar__avatar{width:28px;height:28px;border-radius:50%;background:#fff3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;cursor:pointer}.sidebar{grid-column:1;grid-row:2;background:var(--bg-primary);border-right:.5px solid var(--border);padding:var(--space-4) 0;display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:13px;color:var(--text-secondary);text-decoration:none}.sidebar__item:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar__item--active{color:var(--brand);background:var(--brand-light);font-weight:500;border-right:2px solid var(--brand)}.sidebar__icon{font-size:16px;width:20px;text-align:center}.bottom-nav{display:none}.page{padding:var(--space-6);max-width:1200px}.page__header{margin-bottom:var(--space-6)}.page__title{font-size:20px;font-weight:500;color:var(--text-primary)}.section{margin-bottom:var(--space-8)}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section__title{font-size:14px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-8)}.kpi-tile{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.kpi-tile__value{font-size:28px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.kpi-tile__label{font-size:12px;color:var(--text-secondary)}.kpi-tile__label-en{font-size:11px;color:var(--text-muted)}.document-list{display:flex;flex-direction:column;gap:var(--space-2)}.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--radius-md)}.tag--green{background:var(--green-bg);color:var(--green)}.tag--amber{background:var(--amber-bg);color:var(--amber)}.tag--red{background:var(--red-bg);color:var(--red)}.tag--blue{background:var(--blue-bg);color:var(--blue)}.tag--gray{background:var(--bg-secondary);color:var(--text-muted)}.day-counter{font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--radius-md)}.day-counter--gray{background:var(--bg-secondary);color:var(--text-muted)}.day-counter--amber{background:var(--amber-bg);color:var(--amber)}.day-counter--red{background:var(--red-bg);color:var(--red)}.badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:500}.badge--amber{background:var(--amber-bg);color:var(--amber)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);z-index:1000}.toast{background:var(--text-primary);color:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:13px;max-width:320px}.toast--error{background:var(--red)}.toast--success{background:var(--green)}.toast--info{background:var(--blue)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.empty-state__icon{font-size:40px;margin-bottom:var(--space-4)}.empty-state__title{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state__desc{font-size:13px;color:var(--text-muted);margin-bottom:var(--space-6)}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton--title{height:16px;width:60%;margin-bottom:var(--space-2)}.skeleton--meta{height:12px;width:80%;margin-bottom:var(--space-3)}.skeleton--bar{height:4px;width:100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pending-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8);background:var(--bg-page)}.pending-screen__icon{font-size:48px;margin-bottom:var(--space-4)}.pending-screen__title{font-size:20px;font-weight:500;margin-bottom:var(--space-3)}.pending-screen__desc{font-size:14px;color:var(--text-secondary);margin-bottom:var(--space-2);max-width:400px}.pending-screen__sub{font-size:12px;color:var(--text-muted);max-width:400px}.user-list{display:flex;flex-direction:column;gap:var(--space-2)}.user-row{display:flex;align-items:center;gap:var(--space-4);background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4)}.user-row--pending{border-color:var(--amber-border);background:var(--amber-bg)}.user-row__avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-bg);color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:500;flex-shrink:0}.user-row__info{flex:1}.user-row__name{font-size:13px;font-weight:500;color:var(--text-primary)}.user-row__email{font-size:12px;color:var(--text-muted)}.user-row__company{font-size:11px;color:var(--text-muted)}.user-row__actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.user-row__meta{display:flex;gap:var(--space-2);align-items:center}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted);font-size:14px}@media(max-width:768px){.app-shell{grid-template-columns:1fr;grid-template-rows:44px 1fr 56px}.app-shell__main{grid-column:1}.sidebar{display:none}.bottom-nav{display:flex;grid-column:1;grid-row:3;background:var(--bg-primary);border-top:.5px solid var(--border);padding:0}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-2);text-decoration:none;color:var(--text-muted);font-size:10px}.bottom-nav__item--active{color:var(--brand)}.bottom-nav__icon{font-size:20px}.kpi-strip{grid-template-columns:1fr 1fr}.field-row-2{grid-template-columns:1fr}.page{padding:var(--space-4)}.toast-container{bottom:72px;right:var(--space-4);left:var(--space-4)}.upload-layout,.doc-detail__body{grid-template-columns:1fr}}.page__subtitle{font-size:13px;color:var(--text-muted);margin-top:var(--space-1)}.upload-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.drop-zone{border:1.5px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-12);text-align:center;cursor:pointer;background:var(--bg-primary);transition:border-color .15s}.drop-zone:hover,.drop-zone--active{border-color:var(--blue);background:var(--blue-bg)}.drop-zone__icon{font-size:32px;margin-bottom:var(--space-3)}.drop-zone__text{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.drop-zone__sub{font-size:12px;color:var(--text-muted)}.file-queue{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4)}.file-item{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:12px;cursor:pointer}.file-item__top{display:flex;align-items:center;gap:var(--space-3)}.file-item__name{flex:1;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item__size{color:var(--text-muted);flex-shrink:0}.file-item__progress-wrap{display:flex;flex-direction:column;gap:3px;padding:0 var(--space-1)}.file-item__progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.file-item__progress-fill{height:4px;background:var(--blue);border-radius:2px;transition:width .6s ease}.file-item__progress-label{font-size:10px;color:var(--text-muted)}.file-item__progress-label--done{font-size:10px;color:var(--green);padding:0 var(--space-1)}.file-item__progress-label--blocked{font-size:10px;color:var(--red);padding:0 var(--space-1)}.file-item--selected{border:1px solid var(--blue);background:var(--blue-bg)}.file-item__summary{font-size:11px;color:var(--text-muted);padding:0 var(--space-1);margin-top:2px}.scan-result{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.scan-result__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.scan-result__type{font-size:13px;font-weight:500;color:var(--text-primary)}.scan-result__confidence{font-size:12px;color:var(--text-muted)}.scan-result__classification{font-size:13px;color:var(--text-secondary);margin-bottom:var(--space-2)}.scan-result__amount{font-size:24px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-3)}.scan-result__blocked{background:var(--red-bg);color:var(--red);padding:var(--space-3);border-radius:var(--radius-md);font-size:13px;margin-top:var(--space-3)}.scan-panel--empty{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-12);display:flex;align-items:center;justify-content:center;min-height:200px}.scan-panel__placeholder{color:var(--text-muted);font-size:13px;text-align:center}.scan-section{margin-top:var(--space-3)}.scan-section__label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-2)}.check-row{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-1) 0;font-size:12px;color:var(--text-secondary)}.check-row--pass{color:var(--green)}.check-row--fail{color:var(--amber)}.check-row__note{color:var(--text-muted);font-size:11px}.flag-row{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);margin-bottom:var(--space-1);font-size:12px}.flag-row--hard{background:var(--red-bg);color:var(--red)}.flag-row--soft{background:var(--amber-bg);color:var(--amber)}.flag-row__badge{font-size:10px;font-weight:500;flex-shrink:0;padding:1px 5px;border-radius:3px;background:#00000014}.filter-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-4);border-bottom:.5px solid var(--border)}.filter-tab{padding:var(--space-2) var(--space-3);font-size:13px;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-.5px;font-family:var(--font-ui)}.filter-tab:hover{color:var(--text-primary)}.filter-tab--active{color:var(--text-primary);border-bottom-color:var(--brand);font-weight:500}.btn-back{background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:0;margin-bottom:var(--space-4);font-family:var(--font-ui)}.btn-back:hover{color:var(--text-primary)}.doc-detail__header{margin-bottom:var(--space-6)}.doc-detail__title{font-size:18px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-3)}.doc-detail__meta{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;margin-bottom:var(--space-3);font-size:13px;color:var(--text-secondary)}.doc-detail__body{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.doc-detail__left,.doc-detail__right{display:flex;flex-direction:column;gap:var(--space-4)}.detail-card{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.detail-card--advisory{flex:1}.detail-card__title{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.detail-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:.5px solid var(--border);font-size:12px}.detail-row:last-child{border-bottom:none}.detail-row__key{color:var(--text-muted);min-width:100px}.detail-row__val{color:var(--text-primary);font-weight:500;text-align:right}.advisory-content{font-size:13px;line-height:1.7;color:var(--text-secondary);min-height:100px}.advisory-content h3{font-size:13px;font-weight:500;color:var(--text-primary);margin:var(--space-4) 0 var(--space-2)}.advisory-content strong{font-weight:500;color:var(--text-primary)}.advisory-loading{font-size:11px;color:var(--blue);font-weight:400}.advisory-placeholder{color:var(--text-muted);font-size:13px}.approval-actions{display:flex;flex-direction:column;gap:var(--space-3)}.btn--approve{background:var(--green);color:#fff;height:44px;width:100%;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:500;cursor:pointer;font-family:var(--font-ui)}.btn--approve:hover{opacity:.9}.btn--approve:disabled{opacity:.5;cursor:not-allowed}.btn--reject-outline{background:none;color:var(--red);border:.5px solid var(--red-border);height:44px;width:100%;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;font-family:var(--font-ui)}.reject-panel{display:flex;flex-direction:column;gap:var(--space-3)}.reject-reason{border:.5px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);font-size:14px;font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-primary);resize:vertical;width:100%}.reject-reason:focus{outline:none;border-color:var(--border-focus)}.doc-card__actions{display:flex;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:.5px solid var(--border)}.action-btn{font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--radius-md);border:.5px solid;cursor:pointer;font-family:var(--font-ui)}.action-btn--blue{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.action-btn--green{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.action-btn--amber{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.sla--amber{border-color:var(--amber-border)!important}.sla--red{border-color:var(--red-border)!important}.badge--red{background:var(--red-bg);color:var(--red);border-radius:var(--radius-md);padding:2px 8px;font-size:11px;font-weight:500}.filter-tab__count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--bg-secondary);color:var(--text-muted);font-size:10px;margin-left:4px}.filter-tab--active .filter-tab__count{background:var(--brand-light);color:var(--brand)}.timeline-row{display:flex;gap:10px;padding:var(--space-2) 0;border-bottom:.5px solid var(--border)}.timeline-row:last-child{border-bottom:none}.timeline-row__dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:5px}.timeline-row__content{flex:1}.timeline-row__action{font-size:12px;font-weight:500;color:var(--text-primary)}.timeline-row__meta{font-size:11px;color:var(--text-muted);margin-top:2px}.timeline-row__note{font-size:11px;color:var(--text-secondary);margin-top:3px}.timeline-row__sig{font-size:10px;color:var(--text-muted);font-family:var(--font-mono);margin-top:3px}.notification-list{display:flex;flex-direction:column;gap:var(--space-2)}.notification-item{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);cursor:pointer}.notification-item:hover{border-color:var(--blue-border)}.notification-item--unread{border-left:3px solid var(--blue);background:var(--blue-bg)}.notification-item__message{font-size:13px;color:var(--text-primary);margin-bottom:4px}.notification-item__time{font-size:11px;color:var(--text-muted)}.topbar__bell{position:relative}.topbar__badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;background:var(--red);color:#fff;border-radius:8px;font-size:9px;font-weight:500;display:flex;align-items:center;justify-content:center;padding:0 3px}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-8)}.analytics-kpi{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.analytics-kpi--green{border-left:3px solid var(--green)}.analytics-kpi--red{border-left:3px solid var(--red)}.analytics-kpi--amber{border-left:3px solid var(--amber)}.analytics-kpi__value{font-size:28px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.analytics-kpi__label{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.analytics-kpi__sub{font-size:11px;color:var(--text-muted)}.analytics-section{margin-bottom:var(--space-8)}.analytics-section__title{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-3)}.analytics-card{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6)}.bar-chart{display:flex;align-items:flex-end;gap:var(--space-2);height:120px;padding-bottom:var(--space-2)}.bar-chart__col{display:flex;flex-direction:column;align-items:center;flex:1;height:100%}.bar-chart__bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%}.bar-chart__bar{width:100%;background:var(--blue-bg);border:.5px solid var(--blue-border);border-radius:3px 3px 0 0;position:relative;min-height:4px;transition:height .3s}.bar-chart__bar-blocked{position:absolute;bottom:0;left:0;right:0;background:var(--red-bg);border-top:1px solid var(--red-border);border-radius:0}.bar-chart__label{font-size:10px;color:var(--text-muted);margin-top:4px}.bar-chart__count{font-size:10px;color:var(--text-secondary);font-weight:500}.bar-chart__legend{display:flex;align-items:center;gap:4px;margin-top:var(--space-3);font-size:11px;color:var(--text-muted)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot--blue{background:var(--blue)}.legend-dot--red{background:var(--red)}.rate-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:.5px solid var(--border)}.rate-row:last-child{border-bottom:none}.rate-row__label{font-size:12px;color:var(--text-secondary);min-width:80px;flex-shrink:0}.rate-row__bar-wrap{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.rate-row__bar{height:6px;background:var(--red);border-radius:3px;transition:width .3s}.rate-row__pct{font-size:12px;font-weight:500;color:var(--text-primary);min-width:36px;text-align:right}.rate-row__count{font-size:11px;color:var(--text-muted);min-width:40px;text-align:right}.analytics-value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.value-box{padding:var(--space-4);border-radius:var(--radius-md);text-align:center}.value-box--green{background:var(--green-bg);border:.5px solid var(--green-border)}.value-box--red{background:var(--red-bg);border:.5px solid var(--red-border)}.value-box--amber{background:var(--amber-bg);border:.5px solid var(--amber-border)}.value-box--blue{background:var(--blue-bg);border:.5px solid var(--blue-border)}.value-box__amount{font-size:20px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.value-box__label{font-size:11px;color:var(--text-secondary);margin-bottom:2px}.value-box__count{font-size:10px;color:var(--text-muted)}.decision-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) 0;border-bottom:.5px solid var(--border);font-size:12px}.decision-row:last-child{border-bottom:none}.decision-row__ref{font-weight:500;color:var(--text-primary);flex:1}.decision-row__type{color:var(--text-muted);min-width:80px}.decision-row__amount{color:var(--text-secondary);min-width:100px;text-align:right}.decision-row__status{min-width:60px;text-align:center;font-weight:500}.decision-row__status--approved{color:var(--green)}.decision-row__status--rejected{color:var(--red)}.decision-row__days{color:var(--text-muted);min-width:30px;text-align:right}@media(max-width:768px){.analytics-kpi-grid,.analytics-value-grid{grid-template-columns:1fr 1fr}.rate-row__label{min-width:60px;font-size:11px}}.admin-tabs{display:flex;gap:2px;margin-bottom:var(--space-6);border-bottom:.5px solid var(--border)}.admin-tab{padding:var(--space-2) var(--space-4);font-size:13px;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-.5px;font-family:var(--font-ui);display:flex;align-items:center}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--text-primary);border-bottom-color:var(--brand);font-weight:500}.admin-section{display:flex;flex-direction:column;gap:var(--space-2)}.admin-search{margin-bottom:var(--space-4)}.badge--amber{background:var(--amber-bg);color:var(--amber);border-radius:var(--radius-md);padding:2px 6px;font-size:10px;font-weight:500}.user-row--inactive{opacity:.5}.user-row__time{font-size:11px;color:var(--text-muted);margin-top:2px}.user-row__edit{padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-top:.5px solid var(--border);width:100%}.action-btn--red{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.rules-notice{font-size:12px;color:var(--text-muted);background:var(--amber-bg);border:.5px solid var(--amber-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4)}.rules-group{margin-bottom:var(--space-6)}.rules-group__title{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:.5px solid var(--border)}.rules-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) 0;font-size:12px;border-bottom:.5px solid var(--border)}.rules-row:last-child{border-bottom:none}.rules-row__label{flex:1;color:var(--text-primary)}.rules-row__threshold{color:var(--text-muted);min-width:180px}.rules-row__required{min-width:50px;text-align:right}.audit-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--space-4)}.audit-table{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.audit-header{display:grid;grid-template-columns:140px 120px 90px 100px 1fr;gap:var(--space-3);padding:var(--space-2) var(--space-4);background:var(--bg-secondary);font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:.5px solid var(--border)}.audit-row{display:grid;grid-template-columns:140px 120px 90px 100px 1fr;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-bottom:.5px solid var(--border);font-size:11px;align-items:center}.audit-row:last-child{border-bottom:none}.audit-row:hover{background:var(--bg-secondary)}.audit-row__time{color:var(--text-muted)}.audit-row__actor{color:var(--text-secondary)}.audit-row__doc{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.audit-row__note{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.settings-card{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6)}.settings-card__title{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:.5px solid var(--border)}@media(max-width:768px){.audit-header{display:none}.audit-row{grid-template-columns:1fr;gap:2px}.settings-grid{grid-template-columns:1fr}.admin-tabs{overflow-x:auto}}@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-primary);border-top:.5px solid var(--border);padding:8px 0 max(8px,env(safe-area-inset-bottom));justify-content:space-around}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;text-decoration:none;color:var(--text-muted);min-width:48px}.bottom-nav__item--active{color:var(--brand)}.bottom-nav__icon{font-size:20px;line-height:1}.bottom-nav__label{font-size:10px;font-weight:500;white-space:nowrap}.page{padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.sidebar{display:none!important}.app-shell__main{grid-column:1 / -1!important}}@media(max-width:768px){.doc-detail__body{flex-direction:column!important;gap:var(--space-4)!important}.doc-detail__left,.doc-detail__right{width:100%!important;max-width:100%!important}.doc-detail__title{font-size:18px!important;word-break:break-all}.doc-detail__meta{flex-wrap:wrap;gap:6px}}@media(max-width:768px){.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap!important;padding-bottom:2px}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{flex-shrink:0;white-space:nowrap}}.detail-action-bar{display:none}@media(max-width:768px){.detail-action-bar{display:flex;position:fixed;bottom:calc(64px + env(safe-area-inset-bottom));left:0;right:0;padding:12px 16px;background:var(--bg-primary);border-top:.5px solid var(--border);gap:12px;z-index:99}.detail-action-bar__approve{flex:2;font-size:15px}.detail-action-bar__reject{flex:1;font-size:15px}.kpi-strip{gap:var(--space-2)}}.advisory-error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);color:var(--text-muted);font-size:13px}.detail-page{max-width:800px}.detail-header{margin-bottom:var(--space-4)}.detail-header__title{font-size:20px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2)}.detail-header__meta{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;font-size:13px;color:var(--text-secondary);margin-bottom:var(--space-3)}.detail-header__amount{font-weight:500;color:var(--text-primary);font-size:15px}.detail-sig-card{display:flex;align-items:center;gap:var(--space-3);background:var(--green-bg);border:.5px solid var(--green-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-4);font-size:11px;flex-wrap:wrap}.detail-sig-card__label{font-weight:500;color:var(--green)}.detail-sig-card__sig{font-family:var(--font-mono);color:var(--text-muted)}.detail-sig-card__time{color:var(--text-muted)}.detail-tabs{display:flex;gap:2px;border-bottom:.5px solid var(--border);margin-bottom:var(--space-4)}.detail-tab{display:flex;align-items:center;gap:5px;padding:var(--space-2) var(--space-3);font-size:13px;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-.5px;font-family:var(--font-ui);position:relative;white-space:nowrap}.detail-tab:hover{color:var(--text-primary)}.detail-tab--active{color:var(--text-primary);border-bottom-color:var(--brand);font-weight:500}.detail-tab__icon{font-size:14px}.detail-tab__badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;font-size:9px;font-weight:700}.detail-tab__badge--red{background:var(--red);color:#fff}.detail-tab__badge--green{background:var(--green);color:#fff}.detail-tab-content{padding-bottom:120px}.detail-empty{padding:var(--space-6);text-align:center;color:var(--text-muted);font-size:13px}.detail-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:0}.detail-field-item{background:var(--bg-primary);padding:var(--space-2) var(--space-3)}.detail-field-item__key{font-size:10px;color:var(--text-muted);margin-bottom:2px}.detail-field-item__val{font-size:13px;color:var(--text-primary);word-break:break-word}@media(max-width:768px){.detail-fields-grid{grid-template-columns:1fr}}.advisory-cached-badge{font-size:10px;color:var(--green);font-weight:400;margin-left:6px}.advisory-regenerate{font-size:11px;color:var(--text-muted);background:none;border:none;cursor:pointer;margin-left:auto;font-family:var(--font-ui)}.advisory-regenerate:hover{color:var(--text-primary)}.detail-approve-bar{position:fixed;bottom:calc(0px + env(safe-area-inset-bottom));left:0;right:0;background:var(--bg-primary);border-top:.5px solid var(--border);padding:12px 24px;display:flex;gap:12px;z-index:90;box-shadow:0 -4px 16px #0000000f}.detail-approve-bar--reject{flex-direction:column;padding:16px 24px}.detail-approve-bar__approve{flex:2;padding:14px;font-size:15px;font-weight:600}.detail-approve-bar__reject{flex:1;padding:14px;font-size:15px}@media(max-width:768px){.detail-approve-bar{bottom:calc(64px + env(safe-area-inset-bottom));padding:10px 16px}.detail-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.detail-tabs::-webkit-scrollbar{display:none}.detail-tab{flex-shrink:0}.detail-page{max-width:100%}}.return-dialog{position:absolute;bottom:calc(100% + 8px);left:0;right:0;min-width:280px;background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:0 4px 20px #00000014;z-index:50}.return-dialog__title{font-size:12px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-3)}.return-dialog__options{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--space-3)}.return-option{text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:.5px solid var(--border);background:var(--bg-secondary);font-size:12px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-ui);transition:all .1s}.return-option:hover{border-color:var(--amber-border);background:var(--amber-bg)}.return-option--selected{border-color:var(--amber-border);background:var(--amber-bg);color:var(--amber);font-weight:500}.return-dialog__custom{width:100%;border:.5px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2);font-size:12px;font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-primary);resize:none;margin-bottom:var(--space-3);box-sizing:border-box}.return-dialog__actions{display:flex;gap:var(--space-2)}.stage-bar-wrap{margin-top:8px;width:100%}.stage-bar{display:flex;gap:4px;width:100%;margin-bottom:4px;height:auto;overflow:visible}.stage-bar__segment{flex:1;display:flex;flex-direction:column;gap:4px}.stage-bar__fill{height:4px;width:100%;border-radius:2px;display:block}.stage-bar__label{font-size:9px;color:var(--text-muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.stage-bar__label--active{color:var(--blue);font-weight:500}.stage-nodes{display:flex;align-items:flex-start;gap:0;width:100%;margin:8px 0 4px}.stage-node-wrap{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.stage-node{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;transition:all .2s}.stage-node--complete{background:var(--green);border:2px solid var(--green)}.stage-node--active{background:var(--brand);border:2px solid var(--brand);box-shadow:0 0 0 3px #0d2e4e26}.stage-node--pending{background:var(--bg-primary);border:2px solid var(--border)}.stage-node--blocked,.stage-node--rejected{background:var(--red);border:2px solid var(--red)}.stage-node__icon{font-size:11px;color:#fff;font-weight:700;line-height:1}.stage-node__dot{width:8px;height:8px;border-radius:50%;background:#fff}.stage-node__label{font-size:9px;color:var(--text-muted);margin-top:4px;text-align:center;white-space:nowrap;line-height:1.2}.stage-node__label--active{color:var(--brand);font-weight:600}.stage-node__label--complete{color:var(--green)}.stage-node__label--blocked,.stage-node__label--rejected{color:var(--red)}.stage-connector{position:absolute;top:12px;left:calc(50% + 12px);right:calc(-50% + 12px);height:2px;background:var(--border);z-index:0}.stage-connector--complete{background:var(--green)}.stage-nodes--compact .stage-node{width:18px;height:18px}.stage-nodes--compact .stage-node__icon{font-size:9px}.stage-nodes--compact .stage-node__dot{width:6px;height:6px}.stage-nodes--compact .stage-connector{top:9px}.stage-nodes--compact .stage-node__label{font-size:8px;margin-top:3px}.doc-card-list{display:flex;flex-direction:column;gap:0}.doc-card{background:var(--bg-primary);border-bottom:.5px solid var(--border);padding:16px 20px;cursor:pointer;transition:background .1s;border-left:3px solid transparent}.doc-card:first-child{border-top:.5px solid var(--border)}.doc-card:hover{background:#f8f9ff}.doc-card--overdue,.doc-card--blocked{border-left-color:var(--red)}.doc-card__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.doc-card__meta{display:flex;align-items:center;gap:0;flex-wrap:wrap;min-width:0}.doc-card__date{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.doc-card__dot{font-size:12px;color:var(--border);padding:0 8px;flex-shrink:0}.doc-card__ref{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;flex-shrink:0}.doc-card__desc{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-card__tags{display:flex;align-items:center;gap:6px;flex-shrink:0}.doc-pill{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.02em}.doc-pill--blocked{background:#fee2e2;color:#991b1b}.doc-pill--overdue{background:#fef3c7;color:#92400e}.doc-pill--new{background:#ecfdf5;color:#065f46}.doc-card__bottom{display:flex;align-items:center;justify-content:space-between;gap:16px}.doc-card__approve{padding:6px 16px;background:#2d6a4f;color:#fff;border:none;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-ui);white-space:nowrap;flex-shrink:0;transition:opacity .1s}.doc-card__approve:hover{opacity:.85}.card-chain{display:flex;align-items:flex-start;gap:0}.card-chain__item{display:flex;align-items:center}.card-chain__node{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.card-avatar{width:28px;height:28px;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1.5px solid var(--border);background:var(--bg-secondary);color:var(--text-muted)}.card-avatar--done{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.card-avatar--active{background:var(--brand, #1A365D);border-color:var(--brand, #1A365D);color:#fff;box-shadow:0 0 0 3px #1a365d1f}.card-avatar--blocked{background:#dc2626;border-color:#dc2626;color:#fff}.card-avatar--pending{background:var(--bg-primary);border-color:var(--border);color:var(--text-muted)}.card-avatar__caption{font-size:9px;color:var(--text-muted);white-space:nowrap;text-align:center;line-height:1}.card-avatar__caption--done{color:#2d6a4f}.card-avatar__caption--active{color:var(--brand, #1A365D);font-weight:500}.card-avatar__caption--blocked{color:#dc2626}.card-chain__line{width:24px;height:1.5px;background:var(--border);flex-shrink:0;margin-bottom:13px}.card-chain__line--done{background:#2d6a4f}@media(max-width:768px){.doc-card{padding:14px 16px}.doc-card__dot{padding:0 6px}.doc-card__bottom{flex-wrap:wrap;gap:10px}}.pipeline-layout{display:flex;height:calc(100vh - 56px);overflow:hidden;gap:0}.pipeline-list{width:400px;flex-shrink:0;display:flex;flex-direction:column;border-right:.5px solid var(--border);overflow:hidden}.pipeline-list__header{display:flex;align-items:center;gap:8px;padding:16px 20px 8px;flex-shrink:0}.pipeline-list__title{font-size:18px;font-weight:500;color:var(--text-primary);margin:0}.pipeline-list__count{background:var(--bg-secondary);color:var(--text-muted);font-size:12px;padding:2px 8px;border-radius:10px}.pipeline-list__docs{flex:1;overflow-y:auto;padding:8px 12px 80px;display:flex;flex-direction:column;gap:6px}.pipeline-list__tabs{padding:0 12px;flex-shrink:0}.pipeline-detail{flex:1;overflow-y:auto;background:var(--bg-secondary)}.pipeline-detail__inner{height:100%;position:relative;padding:16px}.pipeline-detail__close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);z-index:10}.pipeline-group__header{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:8px 4px;cursor:pointer;font-family:var(--font-ui);border-radius:6px}.pipeline-group__header:hover{background:var(--bg-secondary)}.pipeline-group__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pipeline-group__dot--amber{background:var(--amber)}.pipeline-group__dot--red{background:var(--red)}.pipeline-group__dot--green{background:var(--green)}.pipeline-group__dot--blue{background:var(--blue)}.pipeline-group__dot--gray{background:var(--border)}.pipeline-group__label{font-size:12px;font-weight:500;color:var(--text-secondary);flex:1;text-align:left}.pipeline-group__count{font-size:11px;color:var(--text-muted);background:var(--bg-secondary);padding:1px 6px;border-radius:8px}.pipeline-group__chevron{font-size:9px;color:var(--text-muted)}.pipeline-group__docs{display:flex;flex-direction:column;gap:6px;padding-left:0;margin-bottom:4px}@media(max-width:1024px){.pipeline-layout{flex-direction:column;height:auto;overflow:visible}.pipeline-list{width:100%;border-right:none;overflow:visible}.pipeline-detail{display:none}}@media(max-width:768px){.pipeline-list__docs{padding-bottom:100px}}.detail-approve-top{display:flex;gap:12px;margin-bottom:16px}.detail-approve-top__approve{flex:2;padding:14px;font-size:15px;font-weight:600;border-radius:10px}.detail-approve-top__reject{flex:1;padding:14px;font-size:14px;border-radius:10px}@media(max-width:768px){.detail-approve-top{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom));left:0;right:0;background:var(--bg-primary);border-top:.5px solid var(--border);padding:10px 16px;margin:0;z-index:90;box-shadow:0 -4px 16px #0000000f}}.page--table{padding:0;max-width:100%}.page--table .pipeline-filters{padding:12px 20px}.approval-table{width:100%;border-top:.5px solid var(--border)}.approval-table__header{display:flex;align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;min-width:0}.approval-table__header .approval-col{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding-top:10px;padding-bottom:10px;border-right:1px solid var(--border)}.approval-table__header .approval-col:last-child{border-right:none}.approval-row{display:flex;align-items:center;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .1s;border-left:3px solid transparent;min-height:52px}.approval-row:hover{background:#f8f9ff}.approval-row:last-child{border-bottom:none}.approval-row--overdue{border-left-color:var(--red)}.approval-col{display:flex;align-items:center;flex-shrink:0;padding-right:0;box-sizing:border-box}.approval-col--check{width:40px;justify-content:center}.approval-col--date{width:110px;flex-direction:column;align-items:flex-start;gap:2px;padding:0 16px}.approval-col--desc{width:180px;overflow:hidden;padding:0 16px}.approval-col--ref{width:200px;flex-direction:column;align-items:flex-start;gap:2px;padding:0 16px}.approval-col--company{width:56px;justify-content:center;padding:0 8px}.approval-col--chain{flex:1;min-width:380px;justify-content:flex-start;padding:0 20px}.approval-col--action{width:80px;justify-content:center;flex-shrink:0}.approval-row__ref{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.3;word-break:break-all}.approval-row__type{font-size:11px;color:var(--text-muted)}.approval-row__company{font-size:10px;font-weight:600;color:var(--text-muted);background:var(--bg-secondary);border:.5px solid var(--border);padding:2px 5px;border-radius:3px;letter-spacing:.04em}.approval-row__desc{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.approval-row__amount{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap}.approval-row__amount--empty{font-size:12px;color:var(--text-muted)}.approval-row__date{font-size:12px;color:var(--text-secondary);line-height:1.3}.approval-row__days{font-size:10px;color:var(--text-muted)}.approval-row__days--overdue{color:var(--red);font-weight:500}.approval-row__approve-btn{padding:4px 10px;background:var(--green);color:#fff;border:none;border-radius:5px;font-size:11px;font-weight:500;cursor:pointer;font-family:var(--font-ui);white-space:nowrap;transition:opacity .1s;line-height:1.4}.approval-row__approve-btn:hover{opacity:.85}.approval-tag{display:inline-flex;align-items:center;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}.approval-tag--overdue{background:#fee2e2;color:#991b1b}.approval-tag--urgent{background:#fef3c7;color:#92400e}.approval-tag--blocked{background:var(--red-bg);color:var(--red)}.approval-chain,.approval-chain__item{display:flex;align-items:center}.approval-chain__line{width:14px;height:1.5px;background:var(--border);flex-shrink:0}.approval-chain__line--done{background:var(--green)}.approval-avatar{width:26px;height:26px;border-radius:50%;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1.5px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);letter-spacing:-.02em}.approval-avatar--done{background:var(--green);border-color:var(--green);color:#fff}.approval-avatar--active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 0 0 3px #0d2e4e1f}.approval-avatar--blocked{background:var(--red);border-color:var(--red);color:#fff}.approval-avatar--pending{background:var(--bg-secondary);border-color:var(--border);color:var(--text-muted)}.pipeline-filters{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:.5px solid var(--border);flex-wrap:wrap;background:var(--bg-primary)}.pipeline-search{display:flex;align-items:center;gap:6px;background:var(--bg-secondary);border:.5px solid var(--border);border-radius:6px;padding:6px 10px;min-width:200px;flex:0 0 auto}.pipeline-search input{border:none;background:none;font-size:13px;color:var(--text-primary);font-family:var(--font-ui);outline:none;width:100%}.pipeline-search input::placeholder{color:var(--text-muted)}.pipeline-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border:.5px solid var(--border);border-radius:6px;font-size:12px;color:var(--text-secondary);background:var(--bg-primary);cursor:pointer;font-family:var(--font-ui);white-space:nowrap;transition:background .1s,border-color .1s}.pipeline-filter-chip:hover{background:var(--bg-secondary)}.pipeline-filter-chip--active{border-color:var(--brand);color:var(--brand);background:#0d2e4e0d}.pipeline-filter-chip--overdue{border-color:var(--red);color:var(--red);background:#fef2f2}.table-pagination{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:12px 20px;border-top:.5px solid var(--border);font-size:12px;color:var(--text-muted)}.table-pagination__btn{background:var(--bg-secondary);border:.5px solid var(--border);border-radius:6px;padding:5px 12px;font-size:12px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-ui)}.table-pagination__btn:hover:not(:disabled){background:var(--bg-primary);border-color:var(--brand);color:var(--brand)}.table-pagination__btn:disabled{opacity:.4;cursor:not-allowed}.table-pagination__info{color:var(--text-muted)}@media(max-width:768px){.approval-table__header{display:none}.approval-row{flex-wrap:wrap;gap:6px;padding:12px 16px;align-items:flex-start;min-height:auto}.approval-col{padding:0}.approval-col--check{display:none}.approval-col--date{width:auto;flex-direction:row;gap:6px;align-items:center}.approval-col--desc,.approval-col--ref{width:100%}.approval-col--company{width:auto}.approval-col--chain{width:100%;min-width:0;overflow-x:auto}.approval-col--action{width:auto;margin-left:auto}.pipeline-search{min-width:0;flex:1}.pipeline-filters{gap:6px;padding:10px 12px}}.ai-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.ai-role-card{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);transition:opacity .15s}.ai-role-card--disabled{opacity:.55}.ai-role-card__header{display:flex;justify-content:space-between;align-items:flex-start}.ai-role-card__name{font-size:14px;font-weight:500;color:var(--text-primary)}.ai-role-card__name-en{font-size:11px;color:var(--text-muted);margin-top:2px}.ai-role-card__purpose{font-size:12px;color:var(--text-secondary);line-height:1.5}.ai-role-card__skills{display:flex;flex-wrap:wrap;gap:var(--space-1)}.ai-role-card__footer{font-size:11px;color:var(--text-muted);border-top:.5px solid var(--border);padding-top:var(--space-2)}.skill-chip{font-size:10px;padding:2px 6px;background:var(--bg-secondary);border:.5px solid var(--border);border-radius:4px;color:var(--text-secondary)}.skill-chip--disabled{opacity:.4;text-decoration:line-through}.skills-table{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--radius-lg);overflow:hidden}.skill-row{background:var(--bg-primary);transition:opacity .15s}.skill-row--disabled{opacity:.6}.skill-row__main{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);cursor:pointer}.skill-row__main:hover{background:var(--bg-secondary)}.skill-row__left,.skill-row__right{display:flex;align-items:center;gap:var(--space-3)}.skill-row__name{font-size:13px;font-weight:500;color:var(--text-primary)}.skill-row__id{font-size:11px;color:var(--text-muted);margin-top:2px;font-family:monospace}.skill-row__expand{font-size:10px;color:var(--text-muted)}.skill-row__detail{padding:var(--space-4);border-top:.5px solid var(--border);background:var(--bg-secondary)}.skill-row__desc{font-size:12px;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-3)}.skill-row__meta{font-size:11px;color:var(--text-muted);margin-top:var(--space-3)}.severity-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:4px;white-space:nowrap}.severity-badge--hard{background:var(--red-bg);color:var(--red)}.severity-badge--soft{background:var(--amber-bg);color:var(--amber)}.severity-badge--info{background:var(--blue-bg);color:var(--blue)}.badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:4px}.badge--blue{background:var(--blue-bg);color:var(--blue)}.skill-params{background:var(--bg-primary);border:.5px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3)}.skill-params__title{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2)}.skill-param-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-1) 0}.skill-param-row__key{font-size:12px;color:var(--text-muted);width:200px;flex-shrink:0;font-family:monospace}.skill-param-row__input{flex:1;border:.5px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:12px;font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-primary)}.skill-param-row__input:focus{outline:none;border-color:var(--brand)}.toggle-switch{width:36px;height:20px;border-radius:10px;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;padding:0}.toggle-switch--on{background:var(--green)}.toggle-switch--off{background:var(--border)}.toggle-switch--disabled{opacity:.4;cursor:not-allowed}.toggle-switch__knob{position:absolute;top:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s}.toggle-switch--on .toggle-switch__knob{left:19px}.toggle-switch--off .toggle-switch__knob{left:3px}.pdf-download-banner{background:var(--green-bg);border:.5px solid var(--green);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--green);gap:var(--space-3);margin-bottom:16px}@media(max-width:768px){.ai-roles-grid{grid-template-columns:1fr}.skill-param-row__key{width:140px}}.dash-table{width:100%;border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.dash-table__header{display:flex;align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.dash-table__header .dash-col{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:10px 16px;border-right:.5px solid var(--border)}.dash-table__header .dash-col:last-child{border-right:none}.dash-row{display:flex;align-items:center;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .1s;border-left:3px solid transparent}.dash-row:last-child{border-bottom:none}.dash-row:hover{background:#f8f9ff}.dash-row--overdue{border-left-color:var(--red)}.dash-col{display:flex;align-items:center;flex-shrink:0;padding:14px 16px}.dash-col--date{width:120px;flex-direction:column;align-items:flex-start;gap:3px}.dash-col--ref{width:200px;flex-direction:column;align-items:flex-start;gap:4px}.dash-col--desc{flex:1;min-width:0;overflow:hidden}.dash-col--chain{width:340px}.dash-col--amount{width:140px;justify-content:flex-end}.dash-row__date{font-size:13px;color:var(--text-primary);font-variant-numeric:tabular-nums}.dash-row__days{font-size:11px;color:var(--text-muted)}.dash-row__days--overdue{color:var(--red);font-weight:500}.dash-row__ref{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.2}.dash-row__desc{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.dash-row__amount{font-size:14px;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.dash-row__amount--empty{font-size:13px;color:var(--text-muted)}.dash-tag{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;letter-spacing:.03em}.dash-tag--blocked{background:var(--red-bg);color:var(--red)}.dash-tag--overdue{background:#fee2e2;color:#991b1b}.dash-chain{display:flex;align-items:flex-start;gap:0}.dash-chain__item{display:flex;align-items:center}.dash-chain__node{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}.dash-avatar{width:32px;height:32px;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1.5px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);letter-spacing:-.02em}.dash-avatar--done{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.dash-avatar--active{background:var(--brand, #1A365D);border-color:var(--brand, #1A365D);color:#fff;box-shadow:0 0 0 3px #1a365d1f}.dash-avatar--blocked{background:var(--red, #DC2626);border-color:var(--red, #DC2626);color:#fff}.dash-avatar--pending{background:var(--bg-primary);border-color:var(--border);color:var(--text-muted)}.dash-avatar__caption{font-size:10px;color:var(--text-muted);white-space:nowrap;line-height:1;text-align:center}.dash-avatar__caption--active{color:var(--brand, #1A365D);font-weight:500}.dash-avatar__caption--done{color:#2d6a4f}.dash-avatar__caption--blocked{color:var(--red)}.dash-chain__line{width:28px;height:1.5px;background:var(--border);flex-shrink:0;margin-bottom:16px}.dash-chain__line--done{background:#2d6a4f}.dash-section{margin-top:28px}.dash-section__header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.dash-section__title{font-size:13px;font-weight:500;color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em}.dash-section__count{font-size:11px;color:var(--text-muted);background:var(--bg-secondary);border:.5px solid var(--border);border-radius:10px;padding:1px 7px}@media(max-width:768px){.dash-table__header{display:none}.dash-row{flex-wrap:wrap;gap:4px;padding:12px 14px;align-items:flex-start}.dash-col{padding:0}.dash-col--date{width:auto;flex-direction:row;gap:6px;align-items:center}.dash-col--ref{width:100%;flex-direction:row;align-items:center;gap:8px}.dash-col--desc{width:100%}.dash-col--chain{width:100%;overflow-x:auto}.dash-col--amount{width:100%;justify-content:flex-start}}
