:root{--bg-base:#080b12;--bg-surface:#0d1020;--bg-card:#111528;--bg-card2:#161b30;--bg-hover:#ffffff08;--border:#ffffff12;--border-md:#ffffff1c;--text-1:#e8eaf6;--text-2:#7c82a0;--text-3:#3d4260;--blue:#4d7cfe;--blue-dim:#4d7cfe1f;--cyan:#22d3ee;--green:#10b981;--green-dim:#10b9811f;--amber:#f59e0b;--amber-dim:#f59e0b1f;--red:#f43f5e;--red-dim:#f43f5e1f;--purple:#8b5cf6;--purple-dim:#8b5cf61f;--orange:#fb923c;--orange-dim:#fb923c1f;--indigo:#6366f1;--indigo-dim:#6366f11f;--teal:#14b8a6;--slate:#64748b;--r-sm:8px;--r-md:12px;--r-lg:16px;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, "Helvetica Neue", Arial, sans-serif}html,body,#root{height:100%;font-family:var(--font-sans);margin:0;padding:0;overflow:hidden}.theme-light{--bg-base:#f4f6fb;--bg-surface:#fff;--bg-card:#fff;--bg-card2:#f8fafd;--bg-hover:#14202e08;--border:#e1e6ee;--border-md:#d3dbe6;--border-strong:#a9b4c4;--text-1:#14202e;--text-2:#5b6b7d;--text-3:#9aa5b1;--accent:#1d6fa5;--accent-dim:#1d6fa51a;--radius-card:var(--r-md);--status-good:#0f6e56;--status-good-dim:#0f6e561a;--status-warn:#854f0b;--status-warn-dim:#ef9f2724;--status-bad:#712b13;--status-bad-dim:#d8573a1f;--blue:var(--accent);--blue-dim:var(--accent-dim);--green:var(--status-good);--green-dim:var(--status-good-dim);--amber:#ef9f27;--amber-dim:var(--status-warn-dim);--red:#d8573a;--red-dim:var(--status-bad-dim);--teal:#0f6e56;--coral:#d8573a;--coral-dim:var(--status-bad-dim);--text-hero:56px;--text-title:28px;--text-metric:22px;--text-body:14px;--text-label:11px;--text-caption:12px;--weight-medium:500;--weight-regular:400;--tracking-tight:-1.5px;--tracking-label:1px;--divider:1px solid var(--border)}.bl-deadline-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.bl-deadline-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.bl-deadline-card--danger{border-color:#f43f5e26}.bl-deadline-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:13px 16px;display:flex}.bl-deadline-badge{border-radius:20px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.bl-deadline-badge--blue{background:var(--blue-dim);color:var(--blue)}.bl-deadline-badge--red{background:var(--red-dim);color:var(--red)}.bl-deadline-list{flex-direction:column;display:flex}.bl-deadline-empty{color:var(--text-3);text-align:center;padding:20px 16px;font-size:12px}.bl-deadline-item{border-bottom:1px solid #ffffff08;align-items:center;gap:10px;padding:10px 16px;transition:background .15s;display:flex}.bl-deadline-item:hover{background:var(--bg-hover)}.bl-deadline-item:last-child{border-bottom:none}.bl-deadline-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.bl-deadline-info{flex:1;min-width:0}.bl-deadline-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:500;overflow:hidden}.bl-deadline-code{color:var(--text-3);margin-top:1px;font-size:10.5px}.bl-deadline-date{color:var(--text-2);flex-shrink:0;font-size:11px}.bl-overdue-tag{background:var(--red-dim);color:var(--red);border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:600}.bl-dashboard{background:var(--bg-base);flex-direction:column;flex:1;gap:14px;padding:20px 22px;display:flex;overflow-y:visible}.bl-dashboard::-webkit-scrollbar{width:4px}.bl-dashboard::-webkit-scrollbar-track{background:0 0}.bl-dashboard::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}.bl-dash-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.bl-dash-title{color:var(--text-1);margin:0 0 4px;font-size:22px;font-weight:700;line-height:1.2}.bl-dash-sub{color:var(--text-3);margin:0;font-size:12px}.bl-dash-header-stats{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);flex-shrink:0;align-items:center;gap:16px;padding:10px 18px;display:flex}.bl-header-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.bl-header-stat-val{font-size:20px;font-weight:700;line-height:1}.bl-header-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.bl-header-stat-div{background:var(--border);width:1px;height:28px}.bl-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.bl-charts-row{grid-template-columns:2fr 1fr;gap:12px;display:grid}.bl-skeleton{background:var(--bg-card);border-radius:var(--r-md);border:1px solid var(--border);animation:1.4s ease-in-out infinite bl-pulse}@keyframes bl-pulse{0%,to{opacity:1}50%{opacity:.5}}.bl-error{background:var(--red-dim);border:1px solid var(--red);border-radius:var(--r-md);color:var(--red);padding:20px;font-size:13px}.bl-no-access{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:70vh;padding:40px 24px;display:flex}.bl-no-access-icon{background:var(--red-dim);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.bl-no-access-title{color:var(--text-1);margin:0;font-size:18px;font-weight:700}.bl-no-access-text{color:var(--text-2);max-width:360px;margin:0;font-size:13px;line-height:1.6}.bl-kpi-grid--simple{grid-template-columns:repeat(2,minmax(180px,320px))}.bl-page-title{font-size:var(--text-title,28px);color:var(--text-1);margin:0 0 4px;font-weight:700;line-height:1.2}.bl-hero-row{align-items:flex-start;gap:32px;display:flex}.bl-hero-stat{flex-direction:column;gap:6px;min-width:160px;display:flex}.bl-label-tag{font-size:var(--text-label,11px);font-weight:var(--weight-medium,500);color:var(--text-3);text-transform:uppercase;letter-spacing:var(--tracking-label,1px)}.bl-hero-number{font-size:var(--text-hero,56px);color:var(--text-1);letter-spacing:var(--tracking-tight,-1.5px);font-weight:700;line-height:1}.bl-hero-context{font-size:var(--text-caption,12px);color:var(--text-3);font-weight:var(--weight-regular,400)}.bl-hero-chart{flex:1;min-width:0}.bl-hero-chart-label{font-size:var(--text-label,11px);font-weight:var(--weight-medium,500);color:var(--text-3);text-transform:uppercase;letter-spacing:var(--tracking-label,1px);margin-bottom:8px}.bl-secondary-strip{border-top:var(--divider,1px solid var(--border));border-bottom:var(--divider,1px solid var(--border));align-items:stretch;gap:0;padding:12px 0;display:flex}.bl-strip-item{flex-direction:column;flex:1;gap:6px;padding:0 24px;display:flex}.bl-strip-item:first-child{padding-left:0}.bl-strip-divider{background:var(--border);flex-shrink:0;align-self:stretch;width:1px}.bl-metric-val{font-size:var(--text-metric,22px);color:var(--text-1);letter-spacing:var(--tracking-tight,-1.5px);font-weight:700;line-height:1}.bl-proj-table{flex-direction:column;gap:0;display:flex}.bl-proj-table-head{border-bottom:var(--divider,1px solid var(--border));justify-content:space-between;align-items:center;margin-bottom:0;padding-bottom:10px;display:flex}.bl-proj-row{border-bottom:var(--divider,1px solid var(--border));grid-template-columns:100px 1fr 120px 48px;align-items:center;gap:12px;padding:10px 0;display:grid}.bl-proj-row:last-child{border-bottom:none}.bl-proj-code{font-family:monospace;font-size:var(--text-caption,12px);color:var(--blue);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.bl-proj-name{font-size:var(--text-body,14px);font-weight:var(--weight-medium,500);color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.bl-proj-prog{align-items:center;display:flex}.bl-proj-prog-track{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.bl-proj-prog-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.bl-proj-pct{font-size:var(--text-metric,22px);color:var(--text-2);text-align:right;letter-spacing:var(--tracking-tight,-1.5px);font-weight:700;line-height:1}.bl-projects-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;overflow:hidden}.bl-pt-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.bl-pt-count{color:var(--text-3);font-size:11px}.bl-pt-scroll{overflow-x:auto}.bl-pt-table{border-collapse:collapse;width:100%;font-size:12px}.bl-pt-table th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:0 8px 8px;font-size:10px;font-weight:600}.bl-pt-table td{color:var(--text-2);border-bottom:1px solid var(--border);padding:8px}.bl-pt-table tr:last-child td{border-bottom:none}.bl-pt-code{white-space:nowrap;font-family:monospace;font-size:11px;color:var(--blue)!important}.bl-pt-client{font-weight:500;color:var(--text-1)!important}.bl-pt-status{background:var(--bg-card2);color:var(--text-3);white-space:nowrap;border:1px solid var(--border);border-radius:10px;padding:2px 6px;font-size:10px;display:inline-block}.bl-pt-prog-cell{align-items:center;gap:8px;min-width:140px;display:flex}.bl-pt-prog-track{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.bl-pt-prog-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.bl-pt-pct{color:var(--text-3);text-align:right;min-width:28px;font-size:10px}.bl-section-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px;position:relative}.bl-section-card:before,.bl-section-card:after{content:"";border:1.5px solid var(--accent);width:9px;height:9px;position:absolute}.bl-section-card:before{border-bottom:none;border-right:none;top:-1px;left:-1px}.bl-section-card:after{border-top:none;border-left:none;bottom:-1px;right:-1px}.bl-section-title{color:var(--text-1);margin:0 0 14px;font-size:13px;font-weight:600}.bl-kpi-row{grid-template-columns:repeat(6,1fr);gap:10px;display:grid}.bl-kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;position:relative}.bl-kpi-card:before,.bl-kpi-card:after{content:"";border:1.5px solid var(--accent);width:8px;height:8px;position:absolute}.bl-kpi-card:before{border-bottom:none;border-right:none;top:-1px;left:-1px}.bl-kpi-card:after{border-top:none;border-left:none;bottom:-1px;right:-1px}.bl-kpi-label{letter-spacing:.03em;color:var(--text-3);text-transform:uppercase;font-size:10px}.bl-kpi-value{color:var(--text-1);letter-spacing:var(--tracking-tight,-1px);margin-top:4px;font-size:22px;font-weight:700;line-height:1.1}.bl-kpi-value--warn{color:var(--status-warn,var(--amber))}.bl-kpi-value--bad{color:var(--status-bad,var(--red))}.bl-section-row{grid-template-columns:1.4fr 1fr;gap:12px;display:grid}.bl-pipeline{align-items:center;display:flex}.bl-pipeline-node{text-align:center;flex:1}.bl-pipeline-count{color:var(--text-1);font-size:19px;font-weight:700}.bl-pipeline-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.02em;margin-top:2px;font-size:10px}.bl-pipeline-connector{flex-shrink:0;width:26px}.bl-status-strip{border-radius:2px;height:4px;margin-top:8px;display:flex;overflow:hidden}.bl-status-seg--good{background:var(--status-good,var(--green))}.bl-status-seg--warn{background:var(--amber)}.bl-status-seg--bad{background:var(--coral,var(--red))}.bl-status-legend{color:var(--text-3);gap:12px;margin-top:14px;font-size:10px;display:flex}.bl-status-legend-dot{border-radius:1px;width:7px;height:7px;margin-right:4px;display:inline-block}.bl-finance-mini-row{gap:16px;margin-bottom:14px;display:flex}.bl-finance-mini-label{color:var(--text-3);text-transform:uppercase;font-size:10px}.bl-finance-mini-value{color:var(--text-1);font-size:17px;font-weight:700}.bl-invoice-status-bar{border-radius:3px;height:10px;margin-bottom:8px;display:flex;overflow:hidden}.bl-invoice-status-legend{flex-direction:column;gap:4px;font-size:11px;display:flex}.bl-invoice-status-legend-row{justify-content:space-between;display:flex}.bl-assign-list{flex-direction:column;gap:7px;display:flex}.bl-assign-row{grid-template-columns:90px 1fr 24px;align-items:center;gap:8px;display:grid}.bl-assign-track{background:var(--accent-dim,var(--blue-dim));border-radius:3px;height:9px;overflow:hidden}.bl-assign-fill{background:var(--accent);border-radius:3px;height:9px}.bl-team-list{flex-direction:column;gap:9px;display:flex}.bl-team-row-head{justify-content:space-between;margin-bottom:3px;font-size:11px;display:flex}.bl-team-track{background:var(--status-good-dim,var(--green-dim));border-radius:3px;height:6px;overflow:hidden}.bl-team-track--warn{background:var(--status-warn-dim,var(--amber-dim))}.bl-team-fill{background:var(--status-good,var(--green));border-radius:3px;height:6px}.bl-team-fill--warn{background:var(--amber)}.bl-team-caption{color:var(--text-3);margin-top:10px;font-size:9px}.bl-log-placeholder{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:32px 16px;display:flex}.bl-log-placeholder-title{color:var(--text-2);font-size:13px;font-weight:500}.bl-log-placeholder-text{color:var(--text-3);max-width:320px;font-size:12px;line-height:1.5}@media (width<=1100px){.bl-kpi-row{grid-template-columns:repeat(3,1fr)}.bl-section-row{grid-template-columns:1fr}}.bl-sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;width:210px;min-width:210px;height:100vh;transition:width .2s,min-width .2s;display:flex;position:relative;overflow:hidden}.bl-sidebar--collapsed{width:56px;min-width:56px}.bl-sb-logo{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:16px 14px 12px;display:flex}.bl-sb-logo-icon{background:linear-gradient(135deg, var(--blue), var(--purple));border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.bl-sb-logo-icon span{color:#fff;font-size:15px;font-weight:800}.bl-sb-logo-name{color:var(--text-1);white-space:nowrap;font-size:14px;font-weight:700}.bl-sb-logo-sub{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;margin-top:1px;font-size:9px;font-weight:600}.bl-sb-toggle{cursor:pointer;color:var(--text-3);background:0 0;border:none;flex-shrink:0;align-items:center;padding:6px 10px;transition:color .15s;display:flex}.bl-sb-toggle:hover{color:var(--text-2)}.bl-sb-section-label{color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;padding:4px 16px 2px;font-size:9px;font-weight:700}.bl-sb-nav{flex-direction:column;flex:1;gap:2px;padding:4px 8px;display:flex;overflow-y:auto}.bl-sb-nav::-webkit-scrollbar{display:none}.bl-sb-item{border-radius:var(--r-sm);cursor:pointer;color:var(--text-2);text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px;font-size:13px;font-weight:400;transition:background .15s,color .15s;display:flex;position:relative}.bl-sb-item:hover{background:var(--bg-hover);color:var(--text-1)}.bl-sb-item--active{background:var(--blue-dim);color:var(--blue);font-weight:600}.bl-sb-item--active:hover{background:var(--blue-dim);color:var(--blue)}.bl-sb-item-indicator{background:var(--blue);border-radius:0 3px 3px 0;width:3px;height:18px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.bl-sb-item-label{flex:1}.bl-sb-user{border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:12px 10px;display:flex}.bl-sb-avatar{background:linear-gradient(135deg, var(--blue), var(--purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.bl-sb-user-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.bl-sb-user-role{color:var(--text-3);white-space:nowrap;text-transform:capitalize;font-size:10px}.bl-sb-user-info{flex:1;min-width:0}.bl-sb-logout{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.bl-sb-logout:hover{color:var(--red);background:var(--red-dim)}.bl-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 22px;display:flex}.bl-topbar-left{flex-direction:column;justify-content:center;display:flex}.bl-topbar-greeting{color:var(--text-2);font-size:14px;font-weight:500;line-height:1.2}.bl-topbar-greeting span{color:var(--text-1);font-weight:600}.bl-topbar-sub{color:var(--text-3);margin-top:1px;font-size:11px}.bl-topbar-right{align-items:center;gap:10px;margin-left:auto;display:flex}.bl-topbar-search{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-3);cursor:text;align-items:center;gap:8px;padding:6px 12px;font-size:12px;transition:border-color .15s;display:flex}.bl-topbar-search:hover{border-color:var(--border-md)}.bl-topbar-search kbd{color:var(--text-3);background:var(--bg-card2);border:1px solid var(--border-md);border-radius:4px;margin-left:20px;padding:1px 5px;font-size:10px}.bl-topbar-icon-btn{border-radius:var(--r-sm);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-2);justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:flex;position:relative}.bl-topbar-icon-btn:hover{background:var(--bg-card2);border-color:var(--border-md);color:var(--text-1)}.bl-topbar-dot{background:var(--red);border:1.5px solid var(--bg-surface);border-radius:50%;width:6px;height:6px;position:absolute;top:6px;right:6px}.bl-topbar-user{border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:8px;padding:4px 8px 4px 4px;transition:background .15s;display:flex}.bl-topbar-user:hover{background:var(--bg-card)}.bl-topbar-avatar{background:linear-gradient(135deg, var(--blue), var(--purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.bl-topbar-user-name{color:var(--text-1);white-space:nowrap;font-size:12px;font-weight:600}.bl-topbar-user-role{color:var(--text-3);text-transform:capitalize;font-size:10px}.gs-trigger{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-3);cursor:pointer;align-items:center;gap:8px;min-width:180px;padding:6px 12px;font-size:12px;transition:border-color .15s,background .15s;display:flex}.gs-trigger:hover{border-color:var(--border-md);color:var(--text-2)}.gs-trigger-text{flex:1}.gs-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#000000bf;justify-content:center;align-items:flex-start;padding-top:80px;display:flex;position:fixed;inset:0}.gs-modal{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border-md);flex-direction:column;width:620px;max-width:calc(100vw - 32px);max-height:calc(100vh - 120px);display:flex;overflow:hidden;box-shadow:0 24px 64px #000000b3,0 0 0 1px #ffffff0a}.gs-input-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 18px;display:flex}.gs-input-icon{color:var(--text-3);flex-shrink:0;display:flex}.gs-input{color:var(--text-1);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:15px}.gs-input::placeholder{color:var(--text-3)}.gs-kbd{background:var(--bg-card2);border:1px solid var(--border-md);color:var(--text-3);cursor:pointer;border-radius:5px;flex-shrink:0;padding:2px 7px;font-family:inherit;font-size:11px}.gs-kbd-esc{cursor:pointer}.gs-kbd-esc:hover{color:var(--text-2)}.gs-spinner{border:2px solid var(--border-md);border-top-color:var(--blue);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite gs-spin}@keyframes gs-spin{to{transform:rotate(360deg)}}.gs-results{max-height:480px;overflow-y:auto}.gs-results::-webkit-scrollbar{width:4px}.gs-results::-webkit-scrollbar-track{background:0 0}.gs-results::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}.gs-section{padding:8px 0}.gs-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:6px 18px 4px;font-size:10px;font-weight:700}.gs-item{cursor:pointer;align-items:center;gap:12px;padding:10px 18px;transition:background .1s;display:flex}.gs-item:hover,.gs-item-active{background:var(--bg-hover)}.gs-item-icon{border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.gs-item-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.gs-item-label{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.gs-item-sub{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.gs-item-badge{letter-spacing:.02em;border-radius:999px;flex-shrink:0;padding:2px 9px;font-size:10.5px;font-weight:600}.gs-footer{color:var(--text-3);border-top:1px solid var(--border);text-align:center;padding:10px 18px;font-size:11px}.gs-empty{text-align:center;color:var(--text-3);padding:40px 18px;font-size:13px}.gs-empty strong{color:var(--text-2)}.gs-hint{text-align:center;color:var(--text-3);padding:24px 18px;font-size:12px}.team-page{background:var(--bg-base);flex-direction:column;gap:14px;padding:20px 22px;display:flex}.team-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.team-header h1{color:var(--text-1);letter-spacing:-.3px;margin:0 0 4px;font-size:22px;font-weight:700;line-height:1.2}.team-header p{color:var(--text-3);margin:0;font-size:12px}.invite-btn{border-radius:var(--r-md);background:var(--blue);color:#fff;cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;height:38px;padding:0 16px;font-size:13px;font-weight:600;transition:all .18s;display:flex;box-shadow:0 2px 8px #4d7cfe59}.invite-btn:hover{background:#3d6ef0;transform:translateY(-1px);box-shadow:0 4px 14px #4d7cfe73}.search-wrapper{background:var(--bg-card);border-radius:var(--r-md);border:1px solid var(--border-md);align-items:center;gap:10px;height:44px;padding:0 16px;transition:border-color .15s;display:flex}.search-wrapper:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}.search-wrapper input{color:var(--text-1);background:0 0;border:none;outline:none;flex:1;font-size:13.5px}.search-wrapper input::placeholder{color:var(--text-3)}.team-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.team-card{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);padding:18px;transition:border-color .15s,transform .15s,box-shadow .15s}.team-card:hover{border-color:var(--border-md);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.team-top{align-items:center;gap:12px;display:flex}.team-avatar{background:linear-gradient(135deg, var(--blue) 0%, #7b9eff 100%);color:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex}.team-top h3{color:var(--text-1);margin:0 0 3px;font-size:15px;font-weight:700}.team-top p{color:var(--text-3);margin:0;font-size:12px}.team-members{color:var(--text-2);align-items:center;gap:8px;margin-top:16px;font-size:13px;display:flex}.team-actions{gap:8px;margin-top:16px;display:flex}.edit-btn,.delete-btn,.save-btn,.cancel-btn{border-radius:var(--r-sm);cursor:pointer;border:none;height:34px;padding:0 14px;font-size:12.5px;font-weight:600;transition:background .15s}.edit-btn{background:var(--blue-dim);color:var(--blue)}.edit-btn:hover{background:#4d7cfe33}.delete-btn{background:var(--red-dim);color:var(--red)}.save-btn{background:var(--blue);color:#fff;box-shadow:0 2px 8px #4d7cfe4d}.save-btn:hover{background:#3d6ef0}.cancel-btn{background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border-md)}.team-table-wrapper{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}.table-header{border-bottom:1px solid var(--border);padding:18px 20px}.table-header h2{color:var(--text-1);margin:0;font-size:15px;font-weight:700}.team-table{border-collapse:collapse;width:100%}.team-table th{background:var(--bg-card2);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);border-bottom:1px solid var(--border-md);padding:12px 16px;font-size:10px;font-weight:700}.team-table td{border-top:1px solid var(--border);color:var(--text-1);padding:13px 16px;font-size:13.5px}.team-table tr:hover td{background:var(--bg-hover)}.table-actions{gap:8px;display:flex}.loading{text-align:center;color:var(--text-3);padding:24px;font-size:13px}.modal{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border-md);width:460px;max-width:100%;padding:24px;box-shadow:0 20px 60px #0009}.modal h2{color:var(--text-1);margin:0 0 20px;font-size:17px;font-weight:700}.form-group{flex-direction:column;margin-bottom:14px;display:flex}.form-group label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:6px;font-size:10px;font-weight:700}.form-group input,.form-group textarea{border:1px solid var(--border-md);border-radius:var(--r-md);background:var(--bg-card2);color:var(--text-1);outline:none;padding:10px 14px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim);background:var(--bg-card)}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.member-select{border:1px solid var(--border-md);border-radius:var(--r-md);background:var(--bg-card2);width:100%;min-height:130px;color:var(--text-1);outline:none;padding:8px;font-size:13px;transition:border-color .15s,box-shadow .15s}.member-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}.member-select option{background:var(--bg-card);color:var(--text-1);padding:6px}.member-hint{color:var(--text-3);margin-top:6px;font-size:11px;display:block}.team-member-list,.table-member-list{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.member-chip{background:var(--blue-dim);color:var(--blue);border-radius:999px;padding:3px 10px;font-size:11.5px;font-weight:600}.no-members{color:var(--text-3);font-size:12px}.form-error{color:var(--red);margin-bottom:8px;font-size:12px}@media (width<=768px){.team-member-list,.table-member-list{gap:6px}.member-chip{padding:3px 8px;font-size:11px}.member-select{min-height:110px}.team-page{padding:14px}}.ed-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400;opacity:0;pointer-events:none;background:#0009;transition:opacity .25s;position:fixed;inset:0}.ed-backdrop--open{opacity:1;pointer-events:all}.ed-drawer{z-index:500;background:#0d1020;border-left:1px solid #ffffff14;flex-direction:column;width:420px;max-width:95vw;height:100vh;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-8px 0 32px #00000080}.ed-drawer--open{transform:translate(0)}.ed-header{border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:18px 20px;display:flex}.ed-header-title{color:#e6e9f0;font-size:15px;font-weight:600}.ed-header-sub{color:#8b93a7;margin-top:3px;font-family:monospace;font-size:11.5px}.ed-close{color:#8b93a7;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff14;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s,color .15s;display:flex}.ed-close:hover{color:#f43f5e;background:#f43f5e1f}.ed-body{flex-direction:column;flex:1;gap:20px;padding:16px 20px;display:flex;overflow-y:auto}.ed-body::-webkit-scrollbar{width:4px}.ed-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.ed-section{flex-direction:column;gap:12px;display:flex}.ed-section-title{color:#3d4260;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid #ffffff0f;padding-bottom:8px;font-size:11px;font-weight:600}.ed-grid{grid-template-columns:1fr 1fr;gap:10px 12px;display:grid}.ed-field{flex-direction:column;gap:5px;display:flex}.ed-field--full{grid-column:1/-1}.ed-req{color:#f43f5e}.ed-field label{color:#8b93a7;font-size:11.5px;font-weight:500}.ed-field input,.ed-field select,.ed-field textarea{color:#e6e9f0;box-sizing:border-box;background:#080b12;border:1px solid #ffffff12;border-radius:8px;outline:none;width:100%;height:36px;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.ed-field select option{background:#111528}.ed-field textarea{resize:vertical;height:auto;padding:8px 10px}.ed-field input::-moz-placeholder{color:#3d4260}.ed-field textarea::-moz-placeholder{color:#3d4260}.ed-field input::placeholder,.ed-field textarea::placeholder{color:#3d4260}.ed-field input:focus,.ed-field select:focus,.ed-field textarea:focus{border-color:#4d7cfe;box-shadow:0 0 0 3px #4d7cfe26}.ed-toggle-wrap{align-items:center;gap:8px;margin-top:4px;display:flex}.ed-toggle{cursor:pointer;background:#ffffff1a;border:1px solid #ffffff1a;border-radius:20px;flex-shrink:0;width:38px;height:22px;transition:background .2s,border-color .2s;position:relative}.ed-toggle--on{background:#4d7cfe;border-color:#4d7cfe}.ed-toggle-thumb{background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000004d}.ed-toggle--on .ed-toggle-thumb{transform:translate(16px)}.ed-toggle-label{color:#8b93a7;font-size:12px}.ed-footer{border-top:1px solid #ffffff12;flex-shrink:0;justify-content:flex-end;align-items:center;gap:8px;padding:14px 20px;display:flex}.ed-btn-cancel{color:#8b93a7;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;align-items:center;height:36px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.ed-btn-cancel:hover{color:#e6e9f0;background:#ffffff14}.ed-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.ed-btn-save{color:#fff;cursor:pointer;background:#4d7cfe;border:none;border-radius:8px;align-items:center;gap:6px;height:36px;padding:0 18px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.ed-btn-save:hover{opacity:.88}.ed-btn-save:disabled{opacity:.5;cursor:not-allowed}@keyframes ed-spin{to{transform:rotate(360deg)}}.ed-spin{animation:.8s linear infinite ed-spin}.pj-page{box-sizing:border-box;background:var(--bg-base);width:100%;padding:24px 28px 48px}.pj-topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.pj-title{color:var(--text-1);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.pj-meta{color:var(--text-2);margin:4px 0 0;font-size:12px}.pj-topbar-actions{align-items:center;gap:10px;display:flex}.pj-btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#4d7cfe;border:none;border-radius:9px;align-items:center;gap:6px;height:38px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.pj-btn-primary:hover{opacity:.88}.pj-btn-secondary{background:var(--bg-card);height:38px;color:var(--text-2);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:9px;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.pj-btn-secondary:hover{background:var(--bg-card2);border-color:var(--border-md);color:var(--text-1)}.pj-filters{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;display:flex}.pj-search-wrap{flex:1;min-width:220px;position:relative}.pj-search-icon{color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.pj-search-input{border:1px solid var(--border);background:var(--bg-surface);width:100%;height:36px;color:var(--text-1);box-sizing:border-box;border-radius:8px;outline:none;padding:0 10px 0 32px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.pj-search-input::placeholder{color:var(--text-3)}.pj-search-input:focus{border-color:#4d7cfe;box-shadow:0 0 0 3px #4d7cfe26}.pj-filter-dropdowns{flex-wrap:wrap;gap:8px;display:flex}.pj-drop-wrap{position:relative}.pj-filter-select{border:1px solid var(--border);background:var(--bg-surface);height:36px;color:var(--text-2);cursor:pointer;appearance:none;border-radius:8px;outline:none;min-width:130px;padding:0 32px 0 12px;font-family:inherit;font-size:12.5px;transition:border-color .15s}.pj-filter-select option{background:var(--bg-card)}.pj-filter-select:focus{border-color:#4d7cfe}.pj-drop-icon{color:var(--text-3);pointer-events:none;position:absolute;top:50%;right:9px;transform:translateY(-50%)}.pj-table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.pj-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.pj-table{border-collapse:collapse;width:100%;min-width:2200px}.pj-th{color:var(--text-3);text-align:left;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:11px 14px;font-size:10px;font-weight:600}.pj-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.pj-row:last-child{border-bottom:none}.pj-row:hover{background:var(--bg-hover)}.pj-row:hover .pj-project-name{color:#4d7cfe}.pj-td{color:var(--text-1);vertical-align:middle;white-space:nowrap;padding:13px 14px;font-size:13px}.pj-td--serial{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:12px}.pj-td--muted{color:var(--text-2)}.pj-td--date{font-size:12.5px}.pj-td--actions{width:80px}.pj-project-cell{flex-direction:column;gap:2px;display:flex}.pj-project-name{color:var(--text-1);font-weight:500;transition:color .15s}.pj-project-code{color:var(--text-3);font-family:monospace;font-size:11px}.pj-site-cell{color:var(--text-2);align-items:center;gap:5px;display:inline-flex}.pj-pin{color:var(--text-3);flex-shrink:0}.pj-team-cell{align-items:center;gap:8px;display:inline-flex}.pj-action-btn{width:30px;height:30px;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.pj-action-btn--edit:hover{color:#4d7cfe;background:#4d7cfe1f}.pj-action-btn--delete:hover{color:#f43f5e;background:#f43f5e1f}.pj-state{color:var(--text-2);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;font-size:14px;display:flex}.pj-state--error{color:#f43f5e}@keyframes pj-spin{to{transform:rotate(360deg)}}.pj-spin{animation:.8s linear infinite pj-spin}@media (width<=768px){.pj-page{padding:16px 14px 40px}.pj-topbar,.pj-filters{flex-direction:column}.pj-search-wrap{width:100%;min-width:unset}.pj-filter-dropdowns{width:100%}.pj-filter-select{min-width:unset;flex:1}}.pj-td--inline{cursor:pointer}.pj-td--inline:hover{background:#6366f10f}.pj-td--editing{cursor:default;padding:4px 8px!important}.pj-inline-value{min-width:60px;display:block}.pj-inline-input,.pj-inline-select{background:var(--bg-card2);border:1px solid var(--indigo);width:100%;min-width:80px;color:var(--text-1);border-radius:6px;outline:none;padding:3px 6px;font-family:inherit;font-size:12px}.pj-inline-saving{color:#6366f1;display:block}.pj-td--number{text-align:right;font-variant-numeric:tabular-nums}.pj-payment-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.pj-payment-badge--paid{background:var(--green-dim);color:var(--green)}.pj-payment-badge--unpaid{background:var(--red-dim);color:var(--red)}.pj-payment-badge--partial{background:var(--amber-dim);color:var(--amber)}.pj-payment-badge--pending{background:var(--blue-dim);color:var(--blue)}.pj-td--expand{cursor:pointer;width:32px;padding:13px 0 13px 14px!important}.pj-expand-icon{color:var(--text-3);transition:transform .18s,color .15s}.pj-expand-icon--open{color:#4d7cfe;transform:rotate(90deg)}.pj-td--expand:hover .pj-expand-icon{color:#4d7cfe}.pj-expand-row,.pj-expand-row:hover{background:var(--bg-surface)}.pj-expand-cell{border-bottom:1px solid var(--border);white-space:normal!important;padding:18px 24px!important}.pj-expand-section{margin-bottom:16px}.pj-expand-section:last-child{margin-bottom:0}.pj-expand-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:10px;font-weight:600}.pj-expand-desc{color:var(--text-2);max-width:720px;font-size:13px;line-height:1.55}.pj-expand-loading,.pj-expand-error,.pj-expand-empty{color:var(--text-3);align-items:center;gap:8px;padding:4px 0;font-size:12.5px;display:flex}.pj-expand-error{color:#f43f5e}.pj-expand-columns{grid-template-columns:1.4fr 1fr;gap:24px;display:grid}.pj-expand-assignment{margin-bottom:10px}.pj-expand-assignment:last-child{margin-bottom:0}.pj-expand-assignment-title{color:var(--text-1);margin-bottom:4px;font-size:12px;font-weight:600}.pj-expand-update{color:var(--text-2);border-left:2px solid var(--border-md);margin-bottom:2px;padding:3px 0 3px 10px;font-size:12px}.pj-expand-update-status{color:#4d7cfe;font-weight:600}.pj-expand-expense{color:var(--text-2);border-bottom:1px solid var(--border);justify-content:space-between;padding:4px 0;font-size:12.5px;display:flex}.pj-expand-expense-amount{color:#10b981;font-variant-numeric:tabular-nums;font-weight:600}.pj-expand-expense-total{color:var(--text-1);justify-content:space-between;margin-top:4px;padding:8px 0 0;font-size:12.5px;font-weight:700;display:flex}@media (width<=900px){.pj-expand-columns{grid-template-columns:1fr}}.pj-td--detail{width:190px;max-width:190px;white-space:normal!important;vertical-align:top!important;padding:10px 12px!important}.pj-detail-desc{color:var(--text-2);max-height:72px;font-size:12px;line-height:1.5;overflow-y:auto}.pj-detail-empty{color:var(--text-3);font-size:11.5px;font-style:italic}.pj-detail-scroll{flex-direction:column;gap:6px;max-height:72px;padding-right:2px;display:flex;overflow-y:auto}.pj-detail-scroll::-webkit-scrollbar{width:4px}.pj-detail-scroll::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}.pj-detail-update{border:1px solid var(--border);background:var(--bg-surface);border-radius:6px;padding:5px 7px}.pj-detail-update-top{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.pj-detail-update-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;font-weight:600;overflow:hidden}.pj-detail-update-status{color:#4d7cfe;white-space:nowrap;flex-shrink:0;font-size:10px;font-weight:600}.pj-detail-update-desc{color:var(--text-2);margin-top:2px;font-size:11px;line-height:1.4}.pj-detail-expense{border:1px solid var(--border);background:var(--bg-surface);border-radius:6px;justify-content:space-between;align-items:center;gap:6px;padding:5px 7px;font-size:11.5px;display:flex}.pj-detail-expense-cat{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pj-detail-expense-amt{color:#10b981;font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:600}.pj-detail-total{color:var(--text-1);border-top:1px solid var(--border);justify-content:space-between;margin-top:6px;padding-top:6px;font-size:11.5px;font-weight:700;display:flex}.pj-detail-attachment{color:var(--text-3);align-items:center;gap:3px;margin-top:3px;font-size:10px;display:inline-flex}.np-page{box-sizing:border-box;background:#f3f6fb;width:100%;max-width:1100px;min-height:100vh;margin:0 auto;padding:40px 32px 70px}.np-topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:30px;display:flex}.np-topbar-left{align-items:flex-start;gap:16px;display:flex}.np-back-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #dbe3ef;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:all .2s;display:inline-flex}.np-back-btn:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.np-title{color:#111827;letter-spacing:-.02em;margin:0;font-size:28px;font-weight:700}.np-subtitle{color:#6b7280;margin-top:4px;font-size:13px}.np-topbar-actions{align-items:center;gap:10px;display:flex}.np-btn-cancel,.np-btn-create{cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;height:42px;padding:0 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.np-btn-cancel{color:#374151;background:#fff;border:1px solid #d1d5db}.np-btn-cancel:hover{background:#f8fafc;border-color:#94a3b8}.np-btn-create{color:#fff;background:#2563eb;border:none}.np-btn-create:hover:not(:disabled){background:#1d4ed8}.np-btn-create:disabled{opacity:.55;cursor:not-allowed}.np-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:13px}.np-form{flex-direction:column;gap:24px;display:flex}.np-section{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:28px;transition:all .2s;box-shadow:0 1px 2px #0f172a0a,0 10px 30px #0f172a0d}.np-section:hover{border-color:#d1d5db}.np-section-title{color:#111827;border-bottom:1px solid #eef2f7;align-items:center;gap:10px;margin:0 0 24px;padding-bottom:14px;font-size:15px;font-weight:700;display:flex}.np-section-subtitle{color:#94a3b8;font-size:12px;font-weight:500}.np-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.np-grid-2{grid-template-columns:repeat(2,1fr)}.np-field--full{grid-column:1/-1}.np-field{flex-direction:column;gap:7px;display:flex}.np-field label{color:#374151;font-size:13px;font-weight:600}.np-field label .np-req{color:#dc2626}.np-field input,.np-field select,.np-field textarea{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;height:44px;padding:0 14px;font-family:inherit;font-size:13px;transition:all .2s}.np-field textarea{resize:vertical;min-height:110px;padding:12px 14px}.np-field input::-moz-placeholder{color:#9ca3af}.np-field textarea::-moz-placeholder{color:#9ca3af}.np-field input::placeholder,.np-field textarea::placeholder{color:#9ca3af}.np-field input:hover,.np-field select:hover,.np-field textarea:hover{border-color:#94a3b8}.np-field input:focus,.np-field select:focus,.np-field textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.np-field select option{color:#111827;background:#fff}.np-field input[readonly]{color:#9ca3af;cursor:not-allowed;background:#f8fafc}.np-field.has-error input,.np-field.has-error select,.np-field.has-error textarea{border-color:#dc2626;box-shadow:0 0 0 4px #dc26261a}.np-err{color:#dc2626;font-size:11px}.np-hint{color:#94a3b8;font-size:11px}.np-toggle-wrap{cursor:pointer;align-items:center;gap:10px;display:inline-flex}.np-toggle-wrap input[type=checkbox]{display:none}.np-toggle-track{background:#d1d5db;border-radius:999px;width:42px;height:24px;transition:all .2s;position:relative}.np-toggle-track:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;top:3px;left:3px;box-shadow:0 2px 6px #00000026}.np-toggle-wrap input:checked~.np-toggle-track{background:#2563eb}.np-toggle-wrap input:checked~.np-toggle-track:after{transform:translate(18px)}.np-toggle-text{color:#374151;font-size:13px;font-weight:500}@keyframes np-spin{to{transform:rotate(360deg)}}.np-spin{animation:.8s linear infinite np-spin}@media (width<=1024px){.np-page{max-width:900px}.np-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.np-page{padding:20px 16px 50px}.np-topbar{flex-direction:column;align-items:stretch}.np-topbar-actions{width:100%}.np-btn-cancel,.np-btn-create{flex:1}.np-grid,.np-grid-2{grid-template-columns:1fr}.np-section{padding:22px}.np-title{font-size:24px}}.quotes-page{background:var(--bg-base);flex-direction:column;flex:1;gap:14px;padding:20px 22px;display:flex;overflow-y:auto}.quotes-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.quotes-header h1{color:var(--text-1);letter-spacing:-.3px;margin:0 0 4px;font-size:22px;font-weight:700;line-height:1.2}.quotes-header p{color:var(--text-3);margin:0;font-size:12px}.add-btn{background:var(--blue);color:#fff;border-radius:var(--r-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:7px;height:38px;padding:0 16px;font-size:13px;font-weight:600;transition:all .18s;display:inline-flex;box-shadow:0 2px 8px #4d7cfe59}.add-btn:hover{background:#3d6ef0;transform:translateY(-1px);box-shadow:0 4px 14px #4d7cfe73}.quotes-table-wrapper{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}.quotes-table{border-collapse:collapse;width:100%}.quotes-table thead{background:var(--bg-card2);border-bottom:1px solid var(--border-md)}.quotes-table th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:13px 16px;font-size:11px;font-weight:700}.quotes-table td{border-top:1px solid var(--border);color:var(--text-1);padding:14px 16px;font-size:13.5px}.quotes-table tbody tr{transition:background .12s}.quotes-table tbody tr:hover{background:var(--bg-hover)}.action-buttons{gap:8px;display:flex}.view-btn{background:var(--blue-dim);height:30px;color:var(--blue);border-radius:var(--r-sm);cursor:pointer;border:none;align-items:center;padding:0 12px;font-size:12px;font-weight:600;transition:background .15s;display:inline-flex}.view-btn:hover{background:#4d7cfe38}.delete-btn{background:var(--red-dim);height:30px;color:var(--red);border-radius:var(--r-sm);cursor:pointer;border:none;align-items:center;padding:0 12px;font-size:12px;font-weight:600;transition:background .15s;display:inline-flex}.delete-btn:hover{background:#f43f5e38}.modal-card{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border-md);width:560px;max-width:100%;overflow:hidden;box-shadow:0 20px 60px #0009}.modal-header h2{color:var(--text-1);margin:0;font-size:16px;font-weight:700}.modal-header button{cursor:pointer;color:var(--text-3);border-radius:var(--r-sm);background:0 0;border:none;padding:4px 6px;font-size:16px;transition:color .15s,background .15s}.modal-header button:hover{color:var(--text-1);background:var(--bg-hover)}.modal-body label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);flex-direction:column;gap:6px;font-size:10px;font-weight:700;display:flex}.modal-body input,.modal-body select,.modal-body textarea{border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-1);background:var(--bg-card2);outline:none;padding:10px 14px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.modal-body select option{background:var(--bg-card);color:var(--text-1)}.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim);background:var(--bg-card)}.modal-body input[type=file]{cursor:pointer;color:var(--text-2);padding:8px 12px}.cancel-btn{border:1px solid var(--border-md);background:var(--bg-card);height:38px;color:var(--text-2);border-radius:var(--r-md);cursor:pointer;align-items:center;padding:0 16px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.cancel-btn:hover{background:var(--bg-hover);color:var(--text-1)}.save-btn{background:var(--blue);color:#fff;border-radius:var(--r-md);cursor:pointer;border:none;align-items:center;height:38px;padding:0 18px;font-size:13px;font-weight:600;transition:all .18s;display:inline-flex;box-shadow:0 2px 8px #4d7cfe59}.save-btn:hover:not(:disabled){background:#3d6ef0;transform:translateY(-1px)}.save-btn:disabled,.cancel-btn:disabled{opacity:.4;cursor:not-allowed}.works-page{background:var(--bg-base);flex-direction:column;flex:1;gap:14px;padding:20px 22px;display:flex;overflow-y:auto}.works-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px;display:flex}.works-header h1{color:var(--text-1);letter-spacing:-.3px;margin:0 0 4px;font-size:22px;font-weight:700;line-height:1.2}.works-header p{color:var(--text-3);margin:0;font-size:12px}.works-grid{grid-template-columns:1fr 300px;align-items:start;gap:14px;display:grid}.works-left{flex-direction:column;gap:14px;display:flex}.works-card{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}.works-card-header{border-bottom:1px solid var(--border);padding:18px 20px 14px}.works-card-header h2{color:var(--text-1);margin:0;font-size:15px;font-weight:700}.works-card-header p{color:var(--text-2);margin:4px 0 0;font-size:12px}.works-card-body{padding:20px}.works-card-footer{border-top:1px solid var(--border);background:var(--bg-card2);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group.full-span{grid-column:1/-1}.form-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-size:10px;font-weight:700}.form-select,.form-input,.form-textarea{border:1px solid var(--border-md);border-radius:var(--r-md);width:100%;color:var(--text-1);background:var(--bg-card2);box-sizing:border-box;outline:none;padding:10px 14px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s,background .15s}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%233d4260' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:14px;padding-right:36px}.form-select option{background:var(--bg-card);color:var(--text-1)}.form-select:focus,.form-input:focus,.form-textarea:focus{border-color:var(--blue);background:var(--bg-card);box-shadow:0 0 0 3px var(--blue-dim)}.form-textarea{resize:vertical;min-height:88px;line-height:1.6}.form-error{color:var(--red);background:var(--red-dim);border-radius:var(--r-md);border:1px solid #f43f5e33;margin-top:12px;padding:10px 14px;font-size:13px}.btn{border-radius:var(--r-md);cursor:pointer;white-space:nowrap;letter-spacing:.01em;border:none;align-items:center;gap:7px;height:38px;padding:0 16px;font-size:13px;font-weight:600;transition:all .18s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 8px #4d7cfe59}.btn-primary:hover:not(:disabled){background:#3d6ef0;transform:translateY(-1px);box-shadow:0 4px 14px #4d7cfe73}.btn-secondary{background:var(--bg-card2);color:var(--text-2);border:1px solid var(--border-md)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-1);border-color:var(--border-md)}.btn-success{background:var(--green-dim);color:var(--green);border:1px solid #10b98133}.btn-success:hover:not(:disabled){background:#10b98133}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #f43f5e33}.btn-danger:hover:not(:disabled){background:#f43f5e33}.btn-sm{border-radius:var(--r-sm);height:30px;padding:0 11px;font-size:12px}.btn-icon{cursor:pointer;color:var(--text-3);border-radius:var(--r-sm);background:0 0;border:none;padding:6px;font-size:15px;line-height:1;transition:color .15s,background .15s}.btn-icon:hover{color:var(--text-1);background:var(--bg-hover)}.team-list{flex-direction:column;gap:2px;padding:8px;display:flex}.team-item{border-radius:var(--r-md);cursor:pointer;align-items:center;gap:12px;padding:11px 12px;transition:background .15s;display:flex}.team-item:hover{background:var(--bg-hover)}.team-item.selected{background:var(--blue-dim)}.team-avatar{color:#fff;background:linear-gradient(135deg,#4d7cfe 0%,#7b9eff 100%);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.team-info{flex:1;min-width:0}.team-name{color:var(--text-1);margin:0;font-size:13px;font-weight:600}.team-meta{color:var(--text-3);margin:2px 0 0;font-size:11.5px}.progress-bar{background:var(--border);border-radius:999px;height:3px;margin-top:6px;overflow:hidden}.progress-fill{border-radius:999px;height:100%;transition:width .4s}.load-low{background:var(--green)}.load-mid{background:var(--amber)}.load-high{background:var(--red)}.load-pct{flex-shrink:0;font-size:12px;font-weight:700}.load-pct.load-low{color:var(--green)}.load-pct.load-mid{color:var(--amber)}.load-pct.load-high{color:var(--red)}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.section-header h2{color:var(--text-1);margin:0;font-size:15px;font-weight:700}.section-header p{color:var(--text-2);margin:4px 0 0;font-size:12px}.review-list{flex-direction:column;display:flex}.review-row{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:13px 20px;transition:background .12s;display:flex}.review-row:last-child{border-bottom:none}.review-row:hover{background:var(--bg-hover)}.review-icon{background:var(--blue-dim);border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;display:flex}.review-info{flex:1;min-width:0}.review-title{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:13px;font-weight:600;overflow:hidden}.review-meta{color:var(--text-3);margin:3px 0 0;font-size:11.5px}.review-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-gray{background:var(--bg-card2);color:var(--text-2)}.badge-blue{background:var(--blue-dim);color:var(--blue)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:999;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border-md);width:520px;max-width:100%;overflow:hidden;box-shadow:0 4px 12px #0000001a,0 8px 24px #00000014}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{color:var(--text-1);margin:0;font-size:16px;font-weight:700}.modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.modal-footer{border-top:1px solid var(--border);background:var(--bg-card2);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.empty-state{text-align:center;color:var(--text-3);padding:48px 24px;font-size:13px}@media (width<=960px){.works-grid{grid-template-columns:1fr}}@media (width<=640px){.works-page{padding:14px}.form-grid{grid-template-columns:1fr}.works-header{flex-direction:column;align-items:flex-start;gap:10px}.review-actions{flex-wrap:wrap}}.wp-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);margin-top:14px;overflow:hidden}.wp-panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px 14px;display:flex}.wp-panel-title{color:var(--text-1);margin:0 0 4px;font-size:15px;font-weight:700}.wp-panel-sub{color:var(--text-3);margin:0;font-size:12px}.wp-filters{flex-wrap:wrap;gap:6px;display:flex}.wp-filter-btn{border:1px solid var(--border-md);background:var(--bg-card2);color:var(--text-3);cursor:pointer;letter-spacing:.02em;border-radius:999px;padding:4px 13px;font-size:11.5px;font-weight:600;transition:all .15s}.wp-filter-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim)}.wp-filter-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 2px 8px #4d7cfe59}.wp-assignments{flex-direction:column;gap:10px;padding:14px 16px 16px;display:flex}.wp-assignment-block{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-card2);transition:border-color .15s;overflow:hidden}.wp-assignment-block:hover{border-color:var(--border-md)}.wp-assignment-header{background:var(--bg-card);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:11px 14px;display:flex}.wp-assignment-info{align-items:center;gap:10px;display:flex}.wp-project-code{color:var(--blue);background:var(--blue-dim);letter-spacing:.04em;border-radius:999px;padding:2px 9px;font-size:10.5px;font-weight:700}.wp-project-name{color:var(--text-1);font-size:13px;font-weight:600}.wp-assignment-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.wp-employee{color:var(--text-2);font-size:11.5px;font-weight:500}.wp-status-badge{letter-spacing:.02em;border-radius:999px;padding:2px 9px;font-size:11px;font-weight:600}.wp-status-badge.wp-status-in_progress{background:var(--amber-dim);color:var(--amber)}.wp-status-badge.wp-status-completed{background:var(--green-dim);color:var(--green)}.wp-photo-count{color:var(--text-3);font-size:11px;font-weight:500}.wp-photo-grid{flex-wrap:wrap;gap:8px;padding:12px 14px;display:flex}.wp-photo-thumb{border-radius:var(--r-md);cursor:pointer;border:1px solid var(--border-md);flex-shrink:0;width:90px;height:90px;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative;overflow:hidden}.wp-photo-thumb:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 6px 18px #4d7cfe40}.wp-photo-thumb img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.wp-photo-thumb:hover img{transform:scale(1.06)}.wp-photo-overlay{opacity:0;background:#4d7cfe59;justify-content:center;align-items:center;font-size:16px;transition:opacity .2s;display:flex;position:absolute;inset:0}.wp-photo-thumb:hover .wp-photo-overlay{opacity:1}.wp-loading-row{gap:8px;padding:12px 14px;display:flex}.wp-photo-skeleton{border-radius:var(--r-md);background:linear-gradient(90deg, var(--bg-card2) 25%, var(--border-md) 50%, var(--bg-card2) 75%);background-size:200% 100%;width:90px;height:90px;animation:1.4s infinite wp-shimmer}@keyframes wp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.wp-empty{text-align:center;color:var(--text-3);padding:48px 20px}.wp-empty-icon{margin-bottom:10px;font-size:32px;display:block}.wp-empty p{margin:0;font-size:13px;font-weight:500}.wp-no-photos{color:var(--text-3);margin:0;padding:12px 14px;font-size:12px;font-style:italic}.wp-error-text{color:var(--red);margin:0;padding:12px 14px;font-size:12px}.wp-lightbox{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#000000e0;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.wp-lightbox-inner{flex-direction:column;align-items:center;gap:14px;max-width:90vw;max-height:90vh;display:flex;position:relative}.wp-lightbox-inner img{border-radius:var(--r-lg);-o-object-fit:contain;object-fit:contain;border:1px solid var(--border-md);max-width:100%;max-height:80vh;box-shadow:0 24px 64px #000000b3}.wp-lightbox-close{background:var(--bg-card);border:1px solid var(--border-md);cursor:pointer;width:30px;height:30px;color:var(--text-1);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:background .15s,transform .15s;display:flex;position:absolute;top:-14px;right:-14px;box-shadow:0 4px 12px #00000080}.wp-lightbox-close:hover{background:var(--bg-card2);transform:scale(1.1)}.wp-lightbox-download{color:var(--text-2);background:var(--bg-card);border:1px solid var(--border-md);border-radius:999px;padding:7px 18px;font-size:12.5px;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.wp-lightbox-download:hover{background:var(--bg-card2);color:var(--text-1)}:root{--bg-base:#080b12;--bg-surface:#0d1020;--bg-card:#111528;--bg-card2:#161b30;--bg-hover:#ffffff08;--border:#ffffff12;--border-md:#ffffff1c;--text-1:#e8eaf6;--text-2:#7c82a0;--text-3:#3d4260;--blue:#4d7cfe;--blue-dim:#4d7cfe1f;--red:#f43f5e;--red-dim:#f43f5e1f;--r-sm:8px;--r-md:12px;--r-lg:16px}.lm-page{background:var(--bg-base);flex-direction:column;height:calc(100vh - 56px);display:flex;overflow:hidden}.lm-header{background:var(--bg-card);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 22px;display:flex}.lm-title{color:var(--text-1);margin:0 0 2px;font-size:20px;font-weight:700}.lm-sub{color:var(--text-3);margin:0;font-size:12px}.lm-header-actions{align-items:center;gap:12px;display:flex}.lm-toggle{color:var(--text-2);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.lm-toggle input{accent-color:var(--blue)}.lm-btn-refresh{background:var(--bg-card2);border:1px solid var(--border-md);border-radius:var(--r-sm);color:var(--text-1);cursor:pointer;padding:7px 16px;font-size:13px;font-weight:600}.lm-btn-refresh:hover{border-color:var(--blue);color:var(--blue)}.lm-body{flex:1;display:flex;overflow:hidden}.lm-sidebar{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;width:280px;padding:14px;display:flex;overflow-y:auto}.lm-sidebar::-webkit-scrollbar{width:4px}.lm-sidebar::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}.lm-section-label{color:var(--text-3);letter-spacing:1.2px;text-transform:uppercase;margin-top:8px;margin-bottom:4px;font-size:10px;font-weight:700}.lm-loading,.lm-empty{color:var(--text-3);padding:12px 0;font-size:13px}.lm-employee-list{flex-direction:column;gap:6px;display:flex}.lm-employee-card{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-card2);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.lm-employee-card:hover,.lm-employee-card.active{border-color:var(--blue);background:var(--blue-dim)}.lm-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.lm-employee-info{flex:1;min-width:0}.lm-employee-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.lm-employee-meta{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.lm-employee-time{color:var(--text-3);margin-top:2px;font-size:10px}.lm-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.lm-history{border-top:1px solid var(--border);margin-top:8px;padding-top:12px}.lm-history-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.lm-clear-btn{cursor:pointer;color:var(--text-3);border-radius:var(--r-sm);background:0 0;border:none;padding:2px 6px;font-size:14px}.lm-clear-btn:hover{color:var(--red);background:var(--red-dim)}.lm-history-list{flex-direction:column;max-height:300px;display:flex;overflow-y:auto}.lm-history-list::-webkit-scrollbar{width:4px}.lm-history-list::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}.lm-history-item{gap:10px;padding-bottom:12px;display:flex;position:relative}.lm-history-dot{z-index:1;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.lm-history-line{background:var(--border-md);width:2px;position:absolute;top:14px;bottom:0;left:4px}.lm-history-content{flex:1}.lm-history-type{color:var(--text-1);font-size:12px;font-weight:600}.lm-history-time{color:var(--text-3);margin-top:1px;font-size:11px}.lm-history-project{color:var(--text-2);margin-top:2px;font-size:11px}.lm-map-wrap{flex:1;position:relative}.lm-map{width:100%;height:100%}.lm-map-loading{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#080b12b3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.lm-spinner{border:3px solid var(--border-md);border-top-color:var(--blue);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite lm-spin}@keyframes lm-spin{to{transform:rotate(360deg)}}.pd-page{box-sizing:border-box;background:var(--bg-base);width:100%;max-width:900px;margin:0 auto;padding:24px 24px 60px}.pd-back-btn{height:32px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;margin-bottom:20px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,background .15s;display:inline-flex}.pd-back-btn:hover{color:var(--text-1);background:var(--bg-hover)}.pd-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.pd-title{color:var(--text-1);letter-spacing:-.02em;margin:0 0 4px;font-size:22px;font-weight:700}.pd-code{color:#4d7cfe;font-family:monospace;font-size:12px;font-weight:600}.pd-header-badge{padding-top:4px}.pd-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:20px;display:flex}.pd-tab{color:var(--text-3);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 22px;font-family:inherit;font-size:13.5px;font-weight:500;transition:color .15s,border-color .15s}.pd-tab:hover{color:var(--text-2)}.pd-tab.pd-tab-active{color:#4d7cfe;border-bottom-color:#4d7cfe;font-weight:600}.pd-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;overflow:hidden}.pd-grid{grid-template-columns:1fr 1fr;display:grid}.pd-field{border-bottom:1px solid var(--border);flex-direction:column;gap:5px;padding:14px 18px;display:flex}.pd-field:nth-child(odd){border-right:1px solid var(--border)}.pd-field-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.pd-field-value{color:var(--text-1);font-size:13.5px;font-weight:500}.pd-assignment-block{padding:20px 24px}.pd-assignment-header{color:var(--text-1);border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:10px;font-size:13px;font-weight:600}.pd-assignment-status{color:var(--text-3);font-weight:400}.pd-timeline{padding-left:24px;position:relative}.pd-timeline:before{content:"";background:var(--border);border-radius:2px;width:2px;position:absolute;top:8px;bottom:8px;left:7px}.pd-timeline-item{margin-bottom:20px;position:relative}.pd-timeline-item:before{content:"";border:2px solid var(--bg-card);background:#8b5cf6;border-radius:50%;width:10px;height:10px;position:absolute;top:5px;left:-17px;box-shadow:0 0 0 3px #8b5cf626}.pd-timeline-date{color:var(--text-3);margin-bottom:4px;font-size:11px}.pd-timeline-status{color:var(--text-1);margin-bottom:4px;font-size:12.5px;font-weight:600}.pd-timeline-note{color:var(--text-2);font-size:13px;line-height:1.5}.pd-timeline-remarks{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-2);border-radius:7px;margin-top:8px;padding:8px 12px;font-size:12px;font-style:italic}.pd-photo-section{margin-top:14px}.pd-photo-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:10px;font-weight:600}.pd-photo-grid{flex-wrap:wrap;gap:8px;display:flex}.pd-photo-thumb{-o-object-fit:cover;object-fit:cover;cursor:pointer;border:1px solid var(--border);border-radius:8px;width:64px;height:64px;transition:transform .15s,box-shadow .15s}.pd-photo-thumb:hover{transform:scale(1.06);box-shadow:0 4px 14px #14202e1f}.pd-expense-table-wrap{overflow-x:auto}.pd-expense-table{border-collapse:collapse;width:100%;font-size:13px}.pd-expense-table thead tr{background:var(--bg-surface);border-bottom:1px solid var(--border)}.pd-expense-table th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;padding:10px 14px;font-size:10px;font-weight:600}.pd-expense-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.pd-expense-table tbody tr:last-child{border-bottom:none}.pd-expense-table tbody tr:hover{background:var(--bg-hover)}.pd-expense-table td{color:var(--text-1);vertical-align:middle;padding:12px 14px}.pd-amount-cell{color:#10b981;font-variant-numeric:tabular-nums;font-weight:600}.pd-expense-total{color:var(--text-1);border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 18px;font-size:14px;font-weight:700;display:flex}.pd-receipt-thumb{-o-object-fit:cover;object-fit:cover;cursor:pointer;border:1px solid var(--border);border-radius:7px;width:48px;height:48px;transition:box-shadow .15s}.pd-receipt-thumb:hover{box-shadow:0 2px 10px #14202e1f}.pd-loader{color:var(--text-2);justify-content:center;align-items:center;gap:10px;padding:48px 20px;font-size:13px;display:flex}.pd-empty{text-align:center;color:var(--text-3);padding:48px 20px;font-size:13px}@keyframes pd-spin{to{transform:rotate(360deg)}}.pd-spin{animation:.8s linear infinite pd-spin}@media (width<=768px){.pd-grid{grid-template-columns:1fr}.pd-field:nth-child(odd){border-right:none}.pd-tabs{overflow-x:auto}.pd-page{padding:14px 14px 40px}}.pd-expense-toolbar{justify-content:flex-end;padding:14px 18px 0;display:flex}.pd-expense-add-btn{color:#fff;cursor:pointer;background:#4d7cfe;border:none;border-radius:8px;align-items:center;gap:6px;height:34px;padding:0 14px;font-family:inherit;font-size:12.5px;font-weight:500;transition:opacity .15s;display:inline-flex}.pd-expense-add-btn:hover{opacity:.88}.pd-expense-edit-btn{width:28px;height:28px;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.pd-expense-edit-btn:hover{color:#4d7cfe;background:#4d7cfe1a}.pd-modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:500;background:#14202e73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.pd-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:100%;max-width:440px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 12px 40px #14202e2e}.pd-modal-header{border-bottom:1px solid var(--border);color:var(--text-1);justify-content:space-between;align-items:center;padding:16px 18px;font-size:14.5px;font-weight:600;display:flex}.pd-modal-close{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.pd-modal-close:hover{color:#f43f5e;background:#f43f5e1a}.pd-modal-body{flex-direction:column;gap:14px;padding:16px 18px;display:flex}.pd-modal-error{color:#dc2626;background:#f43f5e14;border:1px solid #f43f5e40;border-radius:8px;padding:8px 12px;font-size:12.5px}.pd-modal-field{flex-direction:column;gap:5px;display:flex}.pd-modal-field label{color:var(--text-2);font-size:12px;font-weight:500}.pd-req{color:#f43f5e}.pd-modal-field input,.pd-modal-field select,.pd-modal-field textarea{border:1px solid var(--border);background:var(--bg-surface);height:36px;color:var(--text-1);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.pd-modal-field select option{background:var(--bg-card)}.pd-modal-field textarea{resize:vertical;height:auto;padding:8px 10px}.pd-modal-field input:focus,.pd-modal-field select:focus,.pd-modal-field textarea:focus{border-color:#4d7cfe;box-shadow:0 0 0 3px #4d7cfe26}.pd-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:14px 18px;display:flex}.pd-modal-btn-cancel{border:1px solid var(--border);background:var(--bg-surface);height:36px;color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.pd-modal-btn-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.pd-modal-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.pd-modal-btn-save{color:#fff;cursor:pointer;background:#4d7cfe;border:none;border-radius:8px;align-items:center;gap:6px;height:36px;padding:0 18px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.pd-modal-btn-save:hover{opacity:.88}.pd-modal-btn-save:disabled{opacity:.5;cursor:not-allowed}
