:root{--primary:#1a2e4a;--primary-dark:#112039;--primary-light:#243d5e;--accent:#c8a951;--accent-hover:#b8922e;--accent-light:#f5e9c8;--bg:#f0f2f5;--white:#fff;--text-primary:#1a2e4a;--text-secondary:#5a6a7e;--text-muted:#8a9ab0;--border:#dde3ec;--border-light:#eef0f4;--success:#2d8a4e;--success-bg:#e8f5ee;--danger:#c0392b;--danger-bg:#fdecea;--warning:#d4870a;--warning-bg:#fef3e2;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--radius:8px;--radius-sm:4px;--radius-lg:12px;--sidebar-width:260px;--header-height:64px}*{box-sizing:border-box;margin:0;padding:0}body,html{-webkit-font-smoothing:antialiased;background-color:#f0f2f5;background-color:var(--bg);color:#1a2e4a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}#root,body,html{height:100%}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#eef0f4;background:var(--border-light)}::-webkit-scrollbar-thumb{background:#8a9ab0;background:var(--text-muted);border-radius:3px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius);display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-primary{background:#1a2e4a;background:var(--primary);color:#fff;color:var(--white)}.btn-primary:hover{background:#112039;background:var(--primary-dark);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md)}.btn-accent{background:#c8a951;background:var(--accent);color:#1a2e4a;color:var(--primary)}.btn-accent:hover{background:#b8922e;background:var(--accent-hover);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md)}.btn-outline{background:#0000;border:1px solid #dde3ec;border:1px solid var(--border);color:#5a6a7e;color:var(--text-secondary)}.btn-outline:hover{background:#f0f2f5;background:var(--bg);border-color:#5a6a7e;border-color:var(--text-secondary)}.btn-danger{background:#c0392b;background:var(--danger);color:#fff;color:var(--white)}.btn-danger:hover{background:#a93226}.btn-sm{font-size:13px;padding:5px 10px}.btn:disabled{cursor:not-allowed;opacity:.6}.badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:500;padding:3px 8px}.badge-success{background:#e8f5ee;background:var(--success-bg);color:#2d8a4e;color:var(--success)}.badge-danger{background:#fdecea;background:var(--danger-bg);color:#c0392b;color:var(--danger)}.card{background:#fff;background:var(--white);border:1px solid #eef0f4;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm)}.login-page{align-items:center;background:var(--primary);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-page:before{background:#c8a95112;height:520px;right:-160px;top:-160px;width:520px}.login-page:after,.login-page:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.login-page:after{background:#ffffff0a;bottom:-140px;height:440px;left:-120px;width:440px}.login-card{background:#fff;border:none;border-radius:20px;box-shadow:0 24px 64px #00000059;margin:24px;max-width:400px;padding:44px 40px 36px;position:relative;width:100%;z-index:1}.login-card-header{margin-bottom:36px;text-align:center}.login-logo{filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));height:90px;margin-bottom:16px;object-fit:contain;width:auto}.login-company{color:var(--primary);font-size:20px;font-weight:700;letter-spacing:.3px;margin-bottom:4px}.login-subtitle{color:var(--text-secondary);font-size:13px;letter-spacing:.4px}.form-group{margin-bottom:16px}.input-wrapper{position:relative}.input-icon,.input-wrapper{align-items:center;display:flex}.input-icon{color:var(--text-muted);font-size:14px;left:14px;pointer-events:none;position:absolute}.input-wrapper input{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:14px;outline:none;padding:13px 14px 13px 40px;transition:border-color .2s,background .2s,box-shadow .2s;width:100%}.input-wrapper input::placeholder{color:var(--text-muted)}.input-wrapper input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #1a2e4a14}.input-wrapper input.error{border-color:var(--danger)}.input-eye-btn{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:14px;padding:4px;position:absolute;right:12px;transition:color .15s}.input-eye-btn:hover{color:var(--primary)}.form-error{margin-top:5px;padding-left:2px}.login-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:10px;color:var(--danger);font-size:13px;gap:8px;margin-bottom:18px;padding:11px 14px}.login-btn,.login-error{align-items:center;display:flex}.login-btn{background:var(--accent);border:none;border-radius:10px;color:var(--primary);cursor:pointer;font-size:15px;font-weight:700;justify-content:center;letter-spacing:.3px;margin-top:8px;padding:14px;transition:background .2s,box-shadow .2s,transform .1s;width:100%}.login-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 6px 20px #c8a95159;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.65}.login-spinner{animation:spin .7s linear infinite;border:2px solid #1a2e4a4d;border-radius:50%;border-top:2px solid var(--primary);display:inline-block;height:18px;width:18px}.login-footer{color:var(--text-muted);font-size:12px;margin-top:28px;text-align:center}@media (max-width:480px){.login-card{border-radius:16px;padding:36px 24px 28px}}.reset-page{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:24px}.reset-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:460px;padding:48px 40px;width:100%}.reset-header{margin-bottom:36px;text-align:center}.reset-icon{align-items:center;background:var(--accent-light);border-radius:50%;color:var(--accent-hover);display:flex;font-size:28px;height:64px;justify-content:center;margin:0 auto 20px;width:64px}.reset-header h2{color:var(--primary);font-size:24px;font-weight:700;margin-bottom:8px}.reset-header p{color:var(--text-secondary);font-size:14px;line-height:1.5}.reset-alert{align-items:flex-start;background:var(--warning-bg);border:1px solid #d4870a40;border-radius:var(--radius);color:var(--warning);display:flex;font-size:13px;gap:8px;margin-bottom:24px;padding:12px 14px}.reset-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:var(--radius);color:var(--danger)}.reset-error,.reset-success{font-size:13px;margin-bottom:20px;padding:11px 14px}.reset-success{background:var(--success-bg);border:1px solid #2d8a4e33;border-radius:var(--radius);color:var(--success)}.reset-btn{background:var(--primary);border:none;border-radius:var(--radius);color:var(--white);cursor:pointer;font-size:15px;font-weight:600;margin-top:8px;padding:12px;transition:background .2s;width:100%}.reset-btn:hover:not(:disabled){background:var(--primary-dark)}.reset-btn:disabled{cursor:not-allowed;opacity:.7}.password-hint{color:var(--text-muted);font-size:12px;margin-top:5px}@media (max-width:480px){.reset-card{padding:32px 24px}}.main-layout{display:flex;height:100vh;overflow:hidden}.sidebar{background:var(--primary);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:transform .3s ease;width:var(--sidebar-width);z-index:200}.sidebar-brand{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:12px;padding:22px 20px;text-decoration:none}.sidebar-brand-logo{filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));flex-shrink:0;height:40px;object-fit:contain;width:40px}.sidebar-brand-text{flex:1 1;min-width:0}.sidebar-brand-name{color:var(--white);font-size:14px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-brand-sub{color:#ffffff73;font-size:11px;margin-top:1px}.sidebar-nav{flex:1 1;padding:16px 0}.nav-section-label{color:#ffffff59;font-size:10px;font-weight:600;letter-spacing:1px;padding:12px 20px 6px;text-transform:uppercase}.nav-item{align-items:center;border-left:3px solid #0000;color:#ffffffa6;cursor:pointer;display:flex;font-size:14px;font-weight:400;gap:10px;padding:10px 20px;text-decoration:none;transition:all .2s ease}.nav-item:hover{background:#ffffff12;color:var(--white)}.nav-item.active{background:#c8a9511f;border-left-color:var(--accent);color:var(--accent);font-weight:500}.nav-item svg{flex-shrink:0;font-size:16px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-user-info{align-items:center;display:flex;gap:10px;margin-bottom:12px}.sidebar-avatar{align-items:center;background:var(--accent);border-radius:50%;color:var(--primary);display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.sidebar-user-name{color:var(--white);font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#ffffff73;font-size:11px;margin-top:1px}.sidebar-logout-btn{align-items:center;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:var(--radius);color:#ffffffa6;cursor:pointer;display:flex;font-size:13px;gap:8px;padding:8px 10px;transition:all .2s;width:100%}.sidebar-logout-btn:hover{background:#c0392b33;border-color:#c0392b4d;color:#e57373}.main-content{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.header{align-items:center;background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-shrink:0;gap:16px;height:var(--header-height);padding:0 24px;z-index:100}.header-hamburger{background:none;border:none;color:var(--text-primary);cursor:pointer;display:none;font-size:20px;padding:4px}.header-title{color:var(--primary);flex:1 1;font-size:18px;font-weight:600}.header-actions{align-items:center;display:flex;gap:8px}.header-icon-btn{align-items:center;background:var(--bg);border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .2s;width:36px}.header-icon-btn:hover{background:var(--border);color:var(--primary)}.header-user-badge{align-items:center;background:var(--bg);border-radius:20px;display:flex;gap:8px;padding:4px 12px 4px 4px}.header-user-avatar{align-items:center;background:var(--primary);border-radius:50%;color:var(--white);display:flex;font-size:11px;font-weight:700;height:28px;justify-content:center;width:28px}.header-user-name{color:var(--text-primary);font-size:13px;font-weight:500}.page-content{background:var(--bg);flex:1 1;overflow-y:auto;padding:28px}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:150}@media (max-width:900px){.sidebar{height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay.open{display:block}.header-hamburger{display:flex}.page-content{padding:20px 16px}}.dbc{max-width:1400px;padding:4px 0 48px}.dbc__welcome{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.dbc__title{color:#0f172a;font-size:22px;font-weight:800;letter-spacing:-.4px;margin-bottom:4px}.dbc__sub{color:#64748b;font-size:14px}.dbc__actions{display:flex;flex-shrink:0;gap:10px}.dbc__btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:7px;padding:9px 18px;transition:transform .15s,box-shadow .15s,background .15s}.dbc__btn--primary{background:#3b82f6;box-shadow:0 2px 8px #3b82f659;color:#fff}.dbc__btn--primary:hover{background:#2563eb;box-shadow:0 4px 14px #3b82f673;transform:translateY(-1px)}.dbc__btn--outline{background:#fff;border:1.5px solid #bfdbfe;color:#3b82f6}.dbc__btn--outline:hover{background:#eff6ff;transform:translateY(-1px)}.dbc__strip{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 4px #0f172a0d;display:inline-flex;flex-wrap:wrap;gap:0;gap:4px;margin-bottom:28px;padding:12px 20px}.dbc__strip-item{align-items:center;color:#475569;display:flex;font-size:13px;gap:7px;padding:4px 12px}.dbc__strip-item strong{color:#0f172a;font-size:18px;font-weight:800}.dbc__strip-item--alert span,.dbc__strip-item--alert strong{color:#dc2626}.dbc__strip-ico{font-size:13px}.dbc__strip-ico--amber{color:#f59e0b}.dbc__strip-ico--blue{color:#3b82f6}.dbc__strip-sep{background:#e2e8f0;height:28px;margin:0 4px;width:1px}.dbc__sec-label{align-items:center;color:#94a3b8;display:flex;font-size:11px;font-weight:700;gap:8px;letter-spacing:.8px;margin-bottom:16px;text-transform:uppercase}.dbc__sec-count{background:#f1f5f9;border-radius:20px;color:#64748b;font-size:11px;font-weight:700;padding:2px 8px}.dbc__grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dbc-site-card{animation:cardIn .35s ease both;animation-delay:0s;animation-delay:var(--delay,0s);background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;box-shadow:0 1px 4px #0f172a0d;cursor:pointer;display:flex;flex-direction:column;gap:14px;outline:none;padding:20px 22px 16px;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}.dbc-site-card:focus-visible,.dbc-site-card:hover{border-color:#93c5fd;box-shadow:0 8px 28px #0f172a1a;transform:translateY(-3px)}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.dbc-site-card__total{align-items:center;animation:badgePop .3s cubic-bezier(.34,1.56,.64,1);background:#ef4444;border:2px solid #f0f2f5;border-radius:20px;color:#fff;display:flex;font-size:11px;font-weight:800;height:22px;justify-content:center;min-width:22px;padding:0 6px;position:absolute;right:-8px;top:-8px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.dbc-site-card__top{align-items:flex-start;display:flex;gap:12px}.dbc-site-card__site-icon{align-items:center;background:linear-gradient(135deg,#dbeafe,#ede9fe);border-radius:12px;color:#3b82f6;display:flex;flex-shrink:0;font-size:18px;height:44px;justify-content:center;width:44px}.dbc-site-card__info{flex:1 1;min-width:0}.dbc-site-card__name{color:#0f172a;font-size:15px;font-weight:700;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dbc-site-card__addr{align-items:center;color:#94a3b8;display:flex;font-size:12px;gap:5px}.dbc-site-card__chevron{color:#cbd5e1;flex-shrink:0;font-size:12px;margin-top:4px;transition:transform .2s,color .2s}.dbc-site-card:hover .dbc-site-card__chevron{color:#93c5fd;transform:translateX(3px)}.dbc-site-card__incharges{align-items:center;display:flex;flex-wrap:wrap;gap:5px}.dbc-site-card__ic-ico{color:#94a3b8;flex-shrink:0;font-size:11px}.dbc-site-card__ic-chip{background:#f1f5f9;border-radius:20px;color:#475569;font-size:11px;font-weight:500;padding:2px 9px}.dbc-site-card__ic-chip--more{background:#e2e8f0;color:#64748b}.dbc-site-card__footer{align-items:center;background:#f8fafc;border-radius:12px;display:flex;gap:0;padding:10px 14px}.dbc-site-card__stat{align-items:center;display:flex;flex:1 1;gap:6px;justify-content:center}.dbc-site-card__stat-lbl{color:#64748b;font-size:12px;font-weight:600}.dbc-site-card__stat-ico{font-size:12px}.dbc-site-card__stat-ico--amber{color:#f59e0b}.dbc-site-card__stat-ico--blue{color:#3b82f6}.dbc-site-card__sep{background:#e2e8f0;height:24px;margin:0 4px;width:1px}.dbc-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:800;height:20px;justify-content:center;min-width:20px;padding:0 6px}.dbc-badge--amber{background:#fef3c7;color:#d97706}.dbc-badge--blue{background:#dbeafe;color:#2563eb}.dbc-badge-zero{align-items:center;background:#f1f5f9;border-radius:20px;color:#94a3b8;display:inline-flex;font-size:11px;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:0 6px}.dbc-detail{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}.dbc-detail__header{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}.dbc-detail__back{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:7px;padding:7px 14px;transition:background .15s,color .15s;width:fit-content}.dbc-detail__back:hover{background:#e2e8f0;color:#0f172a}.dbc-detail__title-row{align-items:center;display:flex;gap:14px}.dbc-detail__site-icon{align-items:center;background:linear-gradient(135deg,#dbeafe,#ede9fe);border-radius:14px;color:#3b82f6;display:flex;flex-shrink:0;font-size:22px;height:52px;justify-content:center;width:52px}.dbc-detail__name{color:#0f172a;font-size:22px;font-weight:800;letter-spacing:-.4px}.dbc-detail__addr{align-items:center;color:#94a3b8;display:flex;font-size:13px;gap:5px;margin-top:3px}.dbc-detail__pills{display:flex;flex-wrap:wrap;gap:8px}.dbc-detail__pill{align-items:center;border-radius:20px;display:inline-flex;font-size:13px;font-weight:600;gap:7px;padding:7px 14px}.dbc-detail__pill span,.dbc-detail__pill strong{font-size:13px}.dbc-detail__pill-lbl{color:inherit;font-weight:500;opacity:.75}.dbc-detail__pill--amber{background:#fffbeb;color:#d97706}.dbc-detail__pill--blue{background:#eff6ff;color:#2563eb}.dbc-detail__pill--red{background:#fef2f2;color:#dc2626}.dbc-detail__toggle{align-items:center;background:#0000;border:1.5px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:6px 14px;transition:all .15s;width:fit-content}.dbc-detail__toggle:hover{border-color:#93c5fd;color:#3b82f6}.dbc-detail__toggle--on{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.dbc-detail__body{display:flex;flex-direction:column;gap:32px}.dbc-detail__sec-header{align-items:center;display:flex;gap:9px;margin-bottom:16px}.dbc-detail__sec-header h2{color:#0f172a;font-size:15px;font-weight:700}.dbc-detail__sec-ico{font-size:14px}.dbc-detail__sec-ico--amber{color:#f59e0b}.dbc-detail__sec-ico--blue{color:#3b82f6}.dbc-detail__sec-count{background:#f1f5f9;border-radius:20px;color:#475569;font-size:12px;font-weight:700;padding:2px 9px}.dbc-detail__sec-link{background:#0000;border:none;color:#3b82f6;cursor:pointer;font-size:12px;font-weight:600;margin-left:auto;padding:4px 0;transition:opacity .15s}.dbc-detail__sec-link:hover{opacity:.7}.dbc-cards-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.dbc-action-card{animation:cardIn .3s ease both;background:#fff;border:1.5px solid #e2e8f0;border-radius:18px;box-shadow:0 1px 3px #0f172a0d;display:flex;flex-direction:column;gap:12px;padding:18px 20px;transition:transform .2s,box-shadow .2s,border-color .2s}.dbc-action-card:hover{border-color:#bfdbfe;box-shadow:0 6px 20px #0f172a17;transform:translateY(-2px)}.dbc-action-card--urgent{background:linear-gradient(160deg,#fff 60%,#fff5f5);border-color:#fca5a5}.dbc-action-card--rejecting{border-color:#fca5a5}.dbc-action-card__head{align-items:center;display:flex;gap:8px;justify-content:space-between}.dbc-action-card__num{align-items:center;color:#1e3a8a;display:flex;font-size:14px;font-weight:800;gap:7px}.dbc-action-card__type-ico{font-size:12px}.dbc-action-card__type-ico--amber{color:#f59e0b}.dbc-action-card__type-ico--blue{color:#3b82f6}.dbc-urgent-pip{animation:pulse 1.5s infinite;color:#ef4444;font-size:11px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.dbc-action-card__body{display:flex;flex-direction:column;gap:6px}.dbc-action-card__row{align-items:center;display:flex;flex-wrap:wrap;gap:7px}.dbc-action-card__row-ico{color:#94a3b8;flex-shrink:0;font-size:11px}.dbc-action-card__requestor{color:#334155;font-size:13px;font-weight:500}.dbc-action-card__role{background:#f1f5f9;border-radius:6px;color:#94a3b8;font-size:11px;padding:1px 7px}.dbc-action-card__due{color:#64748b;font-size:12px}.dbc-action-card__due--over{color:#ef4444}.dbc-overdue-tag{background:#fef2f2;border-radius:4px;color:#ef4444;font-size:10px;font-weight:800;letter-spacing:.3px;padding:1px 6px}.dbc-action-card__amt{color:#059669;font-size:13px;font-weight:700;margin-left:auto}.dbc-action-card__items{color:#94a3b8;font-size:12px;margin-left:auto}.dbc-action-card__actions{border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:8px;padding-top:10px}.dbc-btn{align-items:center;border:none;border-radius:9px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:7px 13px;transition:transform .15s,opacity .15s,background .15s}.dbc-btn:disabled{cursor:not-allowed;opacity:.55}.dbc-btn--view{background:#f1f5f9;color:#475569}.dbc-btn--view:hover:not(:disabled){background:#e2e8f0;transform:translateY(-1px)}.dbc-btn--approve{background:#dcfce7;color:#16a34a}.dbc-btn--approve:hover:not(:disabled){background:#bbf7d0;transform:translateY(-1px)}.dbc-btn--reject{background:#fee2e2;color:#dc2626}.dbc-btn--reject:hover:not(:disabled){background:#fecaca;transform:translateY(-1px)}.dbc-btn--cancel{background:#f1f5f9;color:#64748b}.dbc-btn--cancel:hover:not(:disabled){background:#e2e8f0}.dbc-btn--confirm-reject{background:#dc2626;color:#fff;flex:1 1}.dbc-btn--confirm-reject:hover:not(:disabled){background:#b91c1c}.dbc-btn--confirm-reject:disabled{background:#fca5a5}.dbc-reject-form{animation:fadeIn .2s ease;border-top:1px solid #fee2e2;display:flex;flex-direction:column;gap:8px;padding-top:10px}.dbc-reject-form__label{color:#dc2626;font-size:12px;font-weight:600}.dbc-reject-form__area{background:#fff5f5;border:1.5px solid #fca5a5;border-radius:9px;color:#334155;font-family:inherit;font-size:13px;outline:none;padding:9px 12px;resize:none;transition:border-color .15s;width:100%}.dbc-reject-form__area:focus{background:#fff;border-color:#ef4444}.dbc-reject-form__btns{display:flex;gap:8px}.dbc-status{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;padding:3px 10px;white-space:nowrap}.dbc-status--amber{background:#fffbeb;color:#d97706}.dbc-status--blue{background:#eff6ff;color:#2563eb}.dbc-status--purple{background:#faf5ff;color:#7c3aed}.dbc-status--green{background:#f0fdf4;color:#16a34a}.dbc-status--emerald{background:#ecfdf5;color:#059669}.dbc-status--red{background:#fef2f2;color:#dc2626}.dbc-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-size:14px;gap:10px;padding:44px 24px;text-align:center}.dbc-empty--page{padding:80px 24px}.dbc-empty__ico{font-size:40px;opacity:.18}.dbc-loader{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-size:14px;gap:16px;justify-content:center;padding:100px 24px}.dbc-loader__ring{animation:spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.dbc-cards-grid,.dbc__grid{grid-template-columns:1fr}.dbc__welcome{align-items:flex-start;flex-direction:column}.dbc__actions{width:100%}.dbc__btn{flex:1 1;justify-content:center}.dbc__strip{justify-content:space-around;width:100%}}.pr-status,.wo-status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;padding:3px 10px;white-space:nowrap}.pr-status.pending_architect,.wo-status-badge.pending_architect{background:#fffbeb;color:#d97706}.pr-status.pending_ed,.wo-status-badge.pending_ed{background:#eff6ff;color:#2563eb}.pr-status.pending_director,.wo-status-badge.pending_director{background:#faf5ff;color:#7c3aed}.pr-status.pending_purchase{background:#f0fdf4;color:#16a34a}.pr-status.rejected,.wo-status-badge.rejected{background:#fef2f2;color:#dc2626}.wo-status-badge.approved{background:#f0fdf4;color:#16a34a}.wo-status-badge.issued{background:#ecfdf5;color:#059669}.users-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.users-page-header h2{color:var(--primary);font-size:22px;font-weight:700}.users-page-header p{color:var(--text-secondary);font-size:13px;margin-top:2px}.users-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.search-input-wrapper{flex:1 1;max-width:360px;min-width:220px;position:relative}.search-input-wrapper svg{color:var(--text-muted);font-size:14px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;outline:none;padding:9px 12px 9px 36px;transition:border-color .2s;width:100%}.search-input:focus{border-color:var(--primary)}.users-table-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.users-table-wrapper{overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table th{background:var(--bg);color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.users-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:14px;padding:13px 16px;vertical-align:middle}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover td{background:#f0f2f580}.user-name-cell{align-items:center;display:flex;gap:10px}.user-avatar-sm{align-items:center;background:var(--primary);border-radius:50%;color:var(--white);display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:34px;justify-content:center;width:34px}.user-name-text{font-weight:500}.user-email-text{color:var(--text-muted);font-size:12px;margin-top:1px}.toggle-switch{display:inline-block;height:22px;position:relative;width:40px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:#ccc;border-radius:22px;cursor:pointer;inset:0;position:absolute;transition:background .2s}.toggle-slider:before{background:#fff;border-radius:50%;content:"";height:16px;left:3px;position:absolute;top:3px;transition:transform .2s;width:16px}input:checked+.toggle-slider{background:var(--success)}input:checked+.toggle-slider:before{transform:translateX(18px)}.action-btns{gap:6px}.action-btn,.action-btns{align-items:center;display:flex}.action-btn{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;height:32px;justify-content:center;transition:all .2s;width:32px}.action-btn-edit{background:#e8f0fa;color:var(--primary)}.action-btn-edit:hover{background:#d0e3f7}.action-btn-key{background:var(--warning-bg);color:var(--warning)}.action-btn-key:hover{background:#fde8b5}.action-btn-delete{background:var(--danger-bg);color:var(--danger)}.action-btn-delete:hover{background:#fbd5d0}.empty-table-state{color:var(--text-muted);padding:48px 24px;text-align:center}.empty-table-state svg{font-size:40px;margin-bottom:12px;opacity:.4}.empty-table-state p{font-size:14px}.confirm-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.confirm-box{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:380px;padding:32px;text-align:center;width:100%}.confirm-icon{font-size:36px;margin-bottom:16px}.confirm-icon.danger{color:var(--danger)}.confirm-icon.warning{color:var(--warning)}.confirm-box h3{color:var(--primary);font-size:18px;font-weight:600;margin-bottom:8px}.confirm-box p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:24px}.confirm-actions{gap:10px}.confirm-actions,.modal-overlay{display:flex;justify-content:center}.modal-overlay{align-items:center;background:#00000073;inset:0;padding:24px;position:fixed;z-index:1000}.modal-box{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:480px;overflow:hidden;width:100%}.modal-header{align-items:center;background:var(--primary);border-bottom:1px solid var(--border);color:var(--white);display:flex;justify-content:space-between;padding:18px 24px}.modal-header h3{font-size:16px;font-weight:600}.modal-close-btn{align-items:center;background:none;border:none;color:#ffffffb3;cursor:pointer;display:flex;font-size:18px;padding:2px;transition:color .2s}.modal-close-btn:hover{color:var(--white)}.modal-body{padding:24px}.modal-form .form-group{margin-bottom:18px}.modal-form .form-group label{color:var(--text-secondary);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}.modal-form .form-group input,.modal-form .form-group select{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s;width:100%}.modal-form .form-group input:focus,.modal-form .form-group select:focus{border-color:var(--primary)}.modal-form .form-group input.error,.modal-form .form-group select.error{border-color:var(--danger)}.modal-footer{background:var(--bg);border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.modal-api-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:var(--radius);color:var(--danger);font-size:13px;margin-bottom:16px;padding:10px 12px}@media (max-width:600px){.users-page-header{align-items:flex-start;flex-direction:column}.users-toolbar{align-items:stretch;flex-direction:column}.search-input-wrapper{max-width:100%}}.master-page-header{margin-bottom:24px}.master-page-header h2{color:var(--primary);font-size:22px;font-weight:700;margin-bottom:4px}.master-page-header p{color:var(--text-secondary);font-size:13px}.master-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:340px 1fr}.master-form-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.master-form-card-header{align-items:center;background:var(--primary);color:var(--white);display:flex;justify-content:space-between;padding:16px 20px}.master-form-card-header h3{font-size:15px;font-weight:600}.master-form-card-header .edit-badge{background:var(--accent);border-radius:10px;color:var(--primary);font-size:11px;font-weight:600;padding:2px 8px}.master-form-body{padding:20px}.master-form-body .form-group{margin-bottom:16px}.master-form-body .form-group label{color:var(--text-secondary);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}.master-form-body .form-group input,.master-form-body .form-group select{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s;width:100%}.master-form-body .form-group input:focus,.master-form-body .form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a2e4a12}.master-form-body .form-group input.error,.master-form-body .form-group select.error{border-color:var(--danger)}.master-form-actions{display:flex;gap:8px;margin-top:4px}.master-form-actions .btn{flex:1 1;justify-content:center}.master-api-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:var(--radius);color:var(--danger);font-size:13px;margin-bottom:14px;padding:9px 12px}.master-list-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.master-list-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:16px 20px}.master-list-header h3{color:var(--primary);font-size:15px;font-weight:600}.master-filter-tabs{display:flex;gap:6px}.filter-tab{background:var(--white);border:1.5px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:5px 12px;transition:all .2s}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:var(--white)}.master-table-wrapper{overflow-x:auto}.master-table{border-collapse:collapse;width:100%}.master-table th{background:var(--bg);color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.master-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:14px;padding:12px 16px;vertical-align:middle}.master-table tbody tr:last-child td{border-bottom:none}.master-table tbody tr:hover td{background:#f0f2f580}.master-table tbody tr.row-editing td{background:var(--accent-light)}.type-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:500;padding:3px 10px}.type-badge.purchase{background:#e8f4fd;color:#2471a3}.type-badge.workorder{background:#e8f8f5;color:#1a8a6e}.master-empty{color:var(--text-muted);font-size:14px;padding:48px 24px;text-align:center}.master-empty svg{display:block;font-size:36px;margin-bottom:10px;margin-left:auto;margin-right:auto;opacity:.35}.count-badge{background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);display:inline-block;font-size:12px;font-weight:500;margin-left:8px;padding:2px 8px}@media (max-width:900px){.master-layout{grid-template-columns:1fr}}.item-form-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.item-form-header{align-items:center;background:var(--primary);color:var(--white);display:flex;justify-content:space-between;padding:16px 24px}.item-form-header h3{font-size:15px;font-weight:600}.item-form-header .edit-badge{background:var(--accent);border-radius:10px;color:var(--primary);font-size:11px;font-weight:600;padding:2px 8px}.item-form-body{padding:24px}.type-toggle{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);display:flex;gap:4px;margin-bottom:24px;padding:4px}.type-toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:7px;justify-content:center;padding:9px 16px;transition:all .2s}.type-toggle-btn:hover{background:#1a2e4a0f;color:var(--primary)}.type-toggle-btn.active.goods{background:var(--primary);box-shadow:var(--shadow-sm);color:var(--white)}.type-toggle-btn.active.service{background:#16a085;box-shadow:var(--shadow-sm);color:var(--white)}.form-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid-full{grid-column:1/-1}.item-form-body .form-group{margin-bottom:16px}.item-form-body .form-group label{color:var(--text-secondary);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}.item-form-body .form-group input,.item-form-body .form-group select,.item-form-body .form-group textarea{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.item-form-body .form-group input:focus,.item-form-body .form-group select:focus,.item-form-body .form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a2e4a12}.item-form-body .form-group input.error,.item-form-body .form-group select.error{border-color:var(--danger)}.item-form-body .form-group textarea{min-height:80px;resize:vertical}.photo-upload-area{border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;padding:20px;position:relative;text-align:center;transition:all .2s}.photo-upload-area:hover{background:#1a2e4a08;border-color:var(--primary)}.photo-upload-area input[type=file]{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.photo-upload-icon{color:var(--text-muted);font-size:28px;margin-bottom:8px}.photo-upload-text{color:var(--text-secondary);font-size:13px}.photo-upload-hint{color:var(--text-muted);font-size:11px;margin-top:4px}.photo-preview{display:inline-block;position:relative}.photo-preview img{border:1px solid var(--border);border-radius:var(--radius);max-height:160px;object-fit:cover;width:100%}.photo-remove-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:26px;justify-content:center;position:absolute;right:6px;top:6px;width:26px}.photo-remove-btn:hover{background:var(--danger)}.qp-section label.qp-label{color:var(--text-secondary);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.qp-list{flex-direction:column;margin-bottom:10px}.qp-list,.qp-row{display:flex;gap:8px}.qp-row{align-items:center}.qp-row input{border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);flex:1 1;font-family:inherit;font-size:14px;outline:none;padding:9px 12px;transition:border-color .2s}.qp-row input:focus{border-color:var(--primary)}.qp-row-num{color:var(--text-muted);flex-shrink:0;font-size:12px;text-align:right;width:24px}.qp-remove-btn{align-items:center;background:var(--danger-bg);border:none;border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;display:flex;flex-shrink:0;font-size:13px;height:30px;justify-content:center;transition:background .2s;width:30px}.qp-remove-btn:hover{background:#fbd5d0}.qp-add-btn{align-items:center;background:#0000;border:1.5px dashed var(--primary);border-radius:var(--radius);color:var(--primary);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:7px 14px;transition:all .2s}.qp-add-btn:hover{background:#1a2e4a0f}.item-form-actions{border-top:1px solid var(--border-light);display:flex;gap:10px;margin-top:8px;padding-top:8px}.item-api-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:var(--radius);color:var(--danger);font-size:13px;margin-bottom:16px;padding:10px 14px}.item-list-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.item-list-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:16px 20px}.item-list-header h3{color:var(--primary);font-size:15px;font-weight:600}.item-table-wrapper{overflow-x:auto}.item-table{border-collapse:collapse;width:100%}.item-table th{background:var(--bg);color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;padding:11px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.item-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:14px;padding:12px 14px;vertical-align:middle}.item-table tbody tr:last-child td{border-bottom:none}.item-table tbody tr:hover td{background:#f0f2f580}.item-table tbody tr.row-editing td{background:var(--accent-light)}.item-type-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:5px;padding:3px 10px}.item-type-badge.goods{background:#e8f0fa;color:#1a4a8a}.item-type-badge.service{background:#e8f8f5;color:#1a6a5e}.item-photo-placeholder,.item-photo-thumb{border:1px solid var(--border);border-radius:var(--radius-sm)}.qp-chips{display:flex;flex-wrap:wrap;gap:4px}.qp-chip{background:#e8f8f5;border-radius:10px;color:#1a6a5e;font-size:11px;font-weight:500;padding:2px 8px}.item-empty{color:var(--text-muted);font-size:14px;padding:48px 24px;text-align:center}.item-empty svg{display:block;font-size:36px;margin-bottom:10px;margin-left:auto;margin-right:auto;opacity:.35}@media (max-width:720px){.form-grid-2{grid-template-columns:1fr}}.pr-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.pr-page-header h2{color:var(--primary);font-size:22px;font-weight:700;margin-bottom:4px}.pr-page-header p{color:var(--text-secondary);font-size:13px}.pr-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}.pr-card-header{align-items:center;background:var(--primary);color:var(--white);display:flex;justify-content:space-between;padding:16px 22px}.pr-card-header h3{font-size:15px;font-weight:600}.pr-card-body{padding:22px}.pr-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.pr-form-grid .full-width{grid-column:1/-1}.pr-form-group{display:flex;flex-direction:column;gap:6px}.pr-form-group label{color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.pr-form-group input,.pr-form-group select,.pr-form-group textarea{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s}.pr-form-group input:focus,.pr-form-group select:focus,.pr-form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a2e4a12}.pr-form-group input.error,.pr-form-group select.error{border-color:var(--danger)}.pr-form-group input:read-only,.pr-form-group input[disabled]{background:var(--bg);color:var(--text-secondary);cursor:default}.form-error{color:var(--danger);font-size:12px}.pr-urgent-row{align-items:center;display:flex;gap:10px;padding:12px 0}.pr-urgent-row input[type=checkbox]{accent-color:var(--danger);cursor:pointer;height:18px;width:18px}.pr-urgent-row label{color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500}.urgent-badge{align-items:center;background:var(--danger-bg);border-radius:20px;color:var(--danger);display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:3px 10px}.pr-items-section{margin-top:8px}.pr-items-table-wrapper{border:1px solid var(--border-light);border-radius:var(--radius);overflow-x:auto}.pr-items-table{border-collapse:collapse;min-width:780px;width:100%}.pr-items-table th{background:var(--bg);color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.pr-items-table td{border-bottom:1px solid var(--border-light);padding:10px 12px;vertical-align:middle}.pr-items-table tbody tr:last-child td{border-bottom:none}.pr-items-table input[type=number],.pr-items-table select{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:13px;outline:none;padding:8px 10px;transition:border-color .2s;width:100%}.pr-items-table input[type=number]:focus,.pr-items-table select:focus{border-color:var(--primary)}.pr-items-table input.error,.pr-items-table select.error{border-color:var(--danger)}.item-photo-thumb{border:1px solid var(--border-light);border-radius:6px;height:40px;object-fit:cover;width:40px}.item-photo-placeholder{background:var(--bg);border-radius:6px;color:var(--text-muted);font-size:16px;height:40px;width:40px}.item-photo-placeholder,.pr-add-row-btn{align-items:center;display:flex;justify-content:center}.pr-add-row-btn{background:none;border:1.5px dashed var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:13px;gap:6px;margin-top:10px;padding:9px 16px;transition:all .2s;width:100%}.pr-add-row-btn:hover{background:#1a2e4a08;border-color:var(--primary);color:var(--primary)}.pr-form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:8px}.pr-api-error{background:var(--danger-bg);border:1px solid #c0392b33;border-radius:var(--radius);color:var(--danger);font-size:13px;margin-bottom:14px;padding:9px 12px}.pr-list-filters{display:flex;flex-wrap:wrap;gap:6px}.pr-filter-tab{background:var(--white);border:1.5px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:5px 13px;transition:all .2s}.pr-filter-tab:hover{border-color:var(--primary);color:var(--primary)}.pr-filter-tab.active{background:var(--primary);border-color:var(--primary);color:var(--white)}.pr-status{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:5px;padding:3px 10px;white-space:nowrap}.pr-status.pending_architect{background:#fef9e7;color:#d68910}.pr-status.pending_ed{background:#eaf4fb;color:#1a70a2}.pr-status.pending_director{background:#f4ecf7;color:#884ea0}.pr-status.pending_purchase{background:#e9f7ef;color:#1e8449}.pr-status.rejected,.pr-urgent-tag{background:var(--danger-bg);color:var(--danger)}.pr-urgent-tag{align-items:center;border-radius:10px;display:inline-flex;font-size:11px;font-weight:700;gap:4px;margin-left:6px;padding:2px 7px}.pr-detail-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr 1fr;margin-bottom:20px}.pr-detail-field label{color:var(--text-secondary);display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.pr-detail-field span{color:var(--text-primary);font-size:14px;font-weight:500}.approval-timeline{display:flex;flex-direction:column;gap:0}.timeline-step{display:flex;gap:14px;position:relative}.timeline-step:not(:last-child):before{background:var(--border-light);bottom:0;content:"";left:17px;position:absolute;top:36px;width:2px}.timeline-dot{align-items:center;background:var(--white);border:2px solid var(--border);border-radius:50%;display:flex;flex-shrink:0;font-size:14px;height:36px;justify-content:center;width:36px;z-index:1}.timeline-dot.approved{background:var(--success-bg);border-color:var(--success);color:var(--success)}.timeline-dot.rejected{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.timeline-dot.pending{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.timeline-dot.waiting{border-color:var(--border);color:var(--text-muted)}.timeline-content{flex:1 1;padding:4px 0 20px}.timeline-content strong{color:var(--primary);font-size:13px;font-weight:600}.timeline-content .timeline-meta{color:var(--text-secondary);font-size:12px;margin-top:2px}.timeline-content .timeline-comment{background:var(--bg);border-left:3px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-size:12px;margin-top:4px;padding:6px 10px}.pr-approval-actions{background:var(--bg);display:flex;gap:10px;padding:18px 22px}.pr-approval-actions,.pr-reject-form{border-top:1px solid var(--border-light)}.pr-reject-form{background:#fff8f8;padding:16px 22px}.pr-reject-form textarea{border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:14px;margin-bottom:10px;outline:none;padding:10px 12px;resize:vertical;transition:border-color .2s;width:100%}.pr-reject-form textarea:focus{border-color:var(--danger)}.adv-filter-bar{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;padding:12px 20px}.adv-search-wrap{flex:1 1;min-width:200px;position:relative}.adv-search-wrap svg{color:var(--text-muted);font-size:13px;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.adv-search-wrap input{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;padding:8px 12px 8px 32px;transition:border-color .2s;width:100%}.adv-search-wrap input:focus{border-color:var(--primary)}.filter-toggle-btn{align-items:center;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:7px;padding:8px 14px;transition:all .2s;white-space:nowrap}.filter-toggle-btn.has-filters,.filter-toggle-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-toggle-btn.has-filters{background:#1a2e4a0d}.filter-badge{align-items:center;background:var(--danger);border-radius:9px;color:#fff;display:inline-flex;font-size:10px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px}.adv-tabs-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:10px 20px}.adv-filter-panel,.adv-tabs-row{border-bottom:1px solid var(--border-light)}.adv-filter-panel{animation:filterSlideDown .18s ease;background:#f8f9fc;padding:16px 20px}@keyframes filterSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.adv-filter-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));margin-bottom:14px}.adv-filter-group{display:flex;flex-direction:column;gap:5px}.adv-filter-group label{color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.adv-filter-group input[type=date],.adv-filter-group input[type=number],.adv-filter-group input[type=text],.adv-filter-group select{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;padding:7px 10px;transition:border-color .2s;width:100%}.adv-filter-group input:focus,.adv-filter-group select:focus{border-color:var(--primary)}.adv-filter-group.checkbox-group{justify-content:flex-end;padding-bottom:2px}.adv-filter-group .urgent-check-row{align-items:center;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;gap:8px;padding:8px 10px}.adv-filter-group .urgent-check-row input[type=checkbox]{accent-color:var(--danger);cursor:pointer;height:15px;width:15px}.adv-filter-group .urgent-check-row label{color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;letter-spacing:0;text-transform:none;white-space:nowrap}.adv-filter-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.adv-filter-result-count{color:var(--text-muted);font-size:12px}.adv-clear-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;padding:6px 14px;transition:all .2s}.adv-clear-btn:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.adv-chips-row{background:var(--white);border-bottom:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:6px;padding:8px 20px}.adv-chip{background:#1a2e4a12;border:1px solid #1a2e4a26;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:5px;padding:3px 8px 3px 10px}.adv-chip,.adv-chip-remove{align-items:center;color:var(--primary)}.adv-chip-remove{background:none;border:none;cursor:pointer;display:flex;font-size:14px;line-height:1;opacity:.6;padding:0}.adv-chip-remove:hover{opacity:1}.adv-result-row{background:var(--bg);border-bottom:1px solid var(--border-light);color:var(--text-muted);font-size:12px;padding:6px 20px}@media (max-width:900px){.pr-form-grid{grid-template-columns:1fr}.adv-filter-grid,.pr-detail-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.adv-filter-grid,.pr-detail-grid{grid-template-columns:1fr}}.wo-status.pending_architect{background:#fef9e7;color:#d68910}.wo-status.pending_ed{background:#eaf4fb;color:#1a70a2}.wo-status.pending_director{background:#f4ecf7;color:#884ea0}.wo-status.approved{background:#e9f7ef;color:#1e8449}.wo-status.issued{background:#1e8449;color:#fff}.wo-status.rejected{background:var(--danger-bg);color:var(--danger)}.wo-item-card{background:var(--bg);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:14px;padding:18px;position:relative}.wo-item-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.wo-item-num{background:#1a2e4a14;border-radius:20px;color:var(--primary);font-size:13px;font-weight:700;padding:3px 10px}.wo-item-remove-btn{align-items:center;background:none;border:1px solid var(--danger);border-radius:var(--radius);color:var(--danger);cursor:pointer;display:flex;font-size:12px;gap:5px;padding:4px 10px;transition:all .2s}.wo-item-remove-btn:hover{background:var(--danger-bg)}.wo-item-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 90px 90px 110px 110px;margin-bottom:12px}.wo-item-field{display:flex;flex-direction:column;gap:4px}.wo-item-field label{color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.wo-item-field input,.wo-item-field select{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;padding:8px 10px;transition:border-color .2s}.wo-item-field input:focus,.wo-item-field select:focus{border-color:var(--primary)}.wo-item-field input.error,.wo-item-field select.error{border-color:var(--danger)}.wo-item-field input:disabled,.wo-item-field input[readonly]{background:var(--bg);color:var(--text-secondary)}.wo-item-desc{margin-bottom:12px}.wo-item-desc label{color:var(--text-secondary);display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.wo-item-desc textarea{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:13px;outline:none;padding:8px 10px;resize:vertical;transition:border-color .2s;width:100%}.wo-item-desc textarea:focus{border-color:var(--primary)}.wo-qp-section label{color:var(--text-secondary);display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.wo-qp-row{align-items:center;display:flex;gap:8px;margin-bottom:6px}.wo-qp-row input{border:1.5px solid var(--border);border-radius:var(--radius);flex:1 1;font-family:inherit;font-size:13px;outline:none;padding:7px 10px;transition:border-color .2s}.wo-qp-row input:focus{border-color:var(--primary)}.wo-qp-remove{align-items:center;background:none;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:13px;height:26px;justify-content:center;transition:all .2s;width:26px}.wo-qp-remove:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.wo-qp-add{background:none;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:12px;margin-top:4px;padding:5px 12px;transition:all .2s}.wo-qp-add:hover{border-color:var(--primary);color:var(--primary)}.wo-charges-table{border-collapse:collapse;margin-bottom:10px;width:100%}.wo-charges-table th{background:var(--bg);color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 12px;text-align:left;text-transform:uppercase}.wo-charges-table td{border-bottom:1px solid var(--border-light);padding:8px 12px;vertical-align:middle}.wo-charges-table input{border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:13px;outline:none;padding:7px 10px;transition:border-color .2s;width:100%}.wo-charges-table input:focus{border-color:var(--primary)}.wo-charges-table input.error{border-color:var(--danger)}.wo-totals{background:var(--bg);border-top:2px solid var(--border-light);display:flex;justify-content:flex-end;padding:16px 22px}.wo-totals-grid{display:flex;flex-direction:column;gap:6px;min-width:260px}.wo-total-row{align-items:center;color:var(--text-secondary);display:flex;font-size:13px;justify-content:space-between}.wo-total-row.grand{border-top:1.5px solid var(--border);color:var(--primary);font-size:15px;font-weight:700;margin-top:4px;padding-top:8px}.wo-total-row span:last-child{color:var(--text-primary);font-weight:600}.wo-total-row.grand span:last-child{color:var(--primary);font-size:17px}.wo-issue-banner{align-items:center;background:#e9f7ef;border-top:1px solid var(--border-light);display:flex;gap:14px;padding:18px 22px}.wo-issue-banner p{color:#1e8449;flex:1 1;font-size:13px;font-weight:500}.wo-issued-info{align-items:center;background:#1e8449;color:#fff;display:flex;font-size:13px;font-weight:600;gap:8px;padding:14px 22px}@media (max-width:900px){.wo-item-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.wo-item-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.9e6481bc.css.map*/