: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}.bl-kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);cursor:default;flex-direction:column;gap:4px;padding:16px;transition:border-color .2s,transform .15s;display:flex;position:relative;overflow:hidden}.bl-kpi:hover{border-color:var(--border-md);transform:translateY(-1px)}.bl-kpi-top{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.bl-kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.bl-kpi-trend{border-radius:20px;padding:3px 8px;font-size:10px;font-weight:600}.bl-kpi-val{color:var(--text-1);font-size:26px;font-weight:600;line-height:1}.bl-kpi-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.bl-kpi-sub{color:var(--text-2);font-size:11px}.bl-kpi-bar{background:var(--border);border-radius:2px;height:3px;margin-top:10px;overflow:hidden}.bl-kpi-bar-fill{border-radius:2px;height:100%;transition:width .6s}.bl-kpi-glow{opacity:.07;pointer-events:none;border-radius:50%;width:80px;height:80px;position:absolute;bottom:-24px;right:-24px}.bl-donut-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.bl-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;padding:14px 16px;display:flex}.bl-card-title{color:var(--text-1);font-size:13px;font-weight:600}.bl-card-sub{color:var(--text-3);font-size:11px}.bl-donut-body{flex-direction:column;align-items:center;gap:16px;padding:16px;display:flex}.bl-donut-svg-wrap{flex-shrink:0;width:140px;height:140px;position:relative}.bl-donut-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.bl-donut-total{color:var(--text-1);font-size:22px;font-weight:600;line-height:1}.bl-donut-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:10px}.bl-donut-legend{flex-direction:column;gap:7px;width:100%;display:flex}.bl-legend-row{align-items:center;gap:8px;font-size:11px;display:flex}.bl-legend-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.bl-legend-name{color:var(--text-2);text-transform:capitalize;flex:1;font-size:11px}.bl-legend-val{color:var(--text-1);font-size:11px;font-weight:600}.bl-legend-pct{color:var(--text-3);text-align:right;min-width:28px;font-size:10px}.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:auto}.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-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;min-height:100vh;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:#080b12;width:100%;min-height:100vh;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:#e6e9f0;letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.pj-meta{color:#8b93a7;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{color:#c8cee0;cursor:pointer;white-space:nowrap;background:#111528;border:1px solid #ffffff14;border-radius:9px;align-items:center;gap:6px;height:38px;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{color:#e6e9f0;background:#161b2e;border-color:#ffffff24}.pj-filters{background:#111528;border:1px solid #ffffff12;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:#3d4260;pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.pj-search-input{color:#e6e9f0;box-sizing:border-box;background:#0d1020;border:1px solid #ffffff12;border-radius:8px;outline:none;width:100%;height:36px;padding:0 10px 0 32px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.pj-search-input::placeholder{color:#3d4260}.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{color:#c8cee0;cursor:pointer;appearance:none;background:#0d1020;border:1px solid #ffffff12;border-radius:8px;outline:none;min-width:130px;height:36px;padding:0 32px 0 12px;font-family:inherit;font-size:12.5px;transition:border-color .15s}.pj-filter-select option{background:#111528}.pj-filter-select:focus{border-color:#4d7cfe}.pj-drop-icon{color:#3d4260;pointer-events:none;position:absolute;top:50%;right:9px;transform:translateY(-50%)}.pj-table-card{background:#111528;border:1px solid #ffffff12;border-radius:14px;overflow:hidden}.pj-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.pj-table{border-collapse:collapse;width:100%;min-width:1100px}.pj-th{color:#3d4260;text-align:left;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;background:#0d1020;border-bottom:1px solid #ffffff0f;padding:11px 14px;font-size:10px;font-weight:600}.pj-row{cursor:pointer;border-bottom:1px solid #ffffff0a;transition:background .12s}.pj-row:last-child{border-bottom:none}.pj-row:hover{background:#ffffff06}.pj-row:hover .pj-project-name{color:#4d7cfe}.pj-td{color:#e6e9f0;vertical-align:middle;white-space:nowrap;padding:13px 14px;font-size:13px}.pj-td--serial{color:#3d4260;font-variant-numeric:tabular-nums;font-size:12px}.pj-td--muted{color:#8b93a7}.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:#e6e9f0;font-weight:500;transition:color .15s}.pj-project-code{color:#3d4260;font-family:monospace;font-size:11px}.pj-site-cell{color:#8b93a7;align-items:center;gap:5px;display:inline-flex}.pj-pin{color:#3d4260;flex-shrink:0}.pj-team-cell{align-items:center;gap:8px;display:inline-flex}.pj-action-btn{color:#3d4260;cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;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:#8b93a7;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}}.np-page{box-sizing:border-box;width:100%;max-width:860px;margin:0 auto;padding:28px 24px 60px}.np-topbar{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.np-topbar-left{align-items:flex-start;gap:14px;display:flex}.np-back-btn{color:#8b93a7;cursor:pointer;background:#111528;border:1px solid #ffffff14;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin-top:2px;transition:background .15s,color .15s;display:inline-flex}.np-back-btn:hover{color:#e6e9f0;background:#161b2e}.np-title{color:#e6e9f0;letter-spacing:-.02em;margin:0 0 4px;font-size:22px;font-weight:700}.np-subtitle{color:#8b93a7;margin:0;font-size:12.5px}.np-topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.np-btn-cancel{color:#c8cee0;cursor:pointer;background:#111528;border:1px solid #ffffff14;border-radius:9px;align-items:center;gap:6px;height:38px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.np-btn-cancel:hover{background:#161b2e}.np-btn-create{color:#fff;cursor:pointer;background:#4d7cfe;border:none;border-radius:9px;align-items:center;gap:6px;height:38px;padding:0 18px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.np-btn-create:hover:not(:disabled){opacity:.88}.np-btn-create:disabled{opacity:.5;cursor:not-allowed}.np-error{color:#f43f5e;background:#f43f5e1a;border:1px solid #f43f5e40;border-radius:9px;margin-bottom:16px;padding:10px 14px;font-size:13px}.np-form{flex-direction:column;gap:14px;display:flex}.np-section{background:#111528;border:1px solid #ffffff12;border-radius:12px;padding:20px 22px 24px;transition:border-color .2s}.np-section:hover{border-color:#ffffff1c}.np-section-title{color:#e6e9f0;border-bottom:1px solid #ffffff0f;align-items:baseline;gap:8px;margin:0 0 16px;padding-bottom:12px;font-size:13.5px;font-weight:600;display:flex}.np-section-subtitle{color:#3d4260;font-size:11px;font-weight:400}.np-grid{grid-template-columns:repeat(2,1fr);gap:14px 16px;display:grid}.np-grid-3{grid-template-columns:repeat(3,1fr)}.np-field{flex-direction:column;gap:5px;display:flex}.np-field--full{grid-column:1/-1}.np-field label{color:#8b93a7;font-size:12px;font-weight:500}.np-field label .np-req{color:#f43f5e;margin-left:2px}.np-field input,.np-field select,.np-field textarea{color:#e6e9f0;box-sizing:border-box;background:#0d1020;border:1px solid #ffffff12;border-radius:8px;outline:none;width:100%;height:38px;padding:0 12px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.np-field select option{background:#111528}.np-field textarea{resize:vertical;height:auto;padding:9px 12px}.np-field input::-moz-placeholder{color:#3d4260}.np-field textarea::-moz-placeholder{color:#3d4260}.np-field input::placeholder,.np-field textarea::placeholder{color:#3d4260}.np-field input:focus,.np-field select:focus,.np-field textarea:focus{border-color:#4d7cfe;box-shadow:0 0 0 3px #4d7cfe26}.np-field input[readonly]{color:#3d4260;cursor:not-allowed;background:#080b12;font-family:monospace}.np-field.has-error input,.np-field.has-error select,.np-field.has-error textarea{border-color:#f43f5e;box-shadow:0 0 0 3px #f43f5e1f}.np-err{color:#f43f5e;font-size:11.5px}.np-hint{color:#3d4260;font-size:11px}.np-toggle-wrap{cursor:pointer;align-items:center;gap:8px;display:inline-flex}.np-toggle-wrap input[type=checkbox]{display:none}.np-toggle-track{background:#ffffff1a;border:1px solid #ffffff1a;border-radius:20px;flex-shrink:0;width:38px;height:22px;transition:background .2s,border-color .2s;position:relative}.np-toggle-track:after{content:"";background:#8b93a7;border-radius:50%;width:14px;height:14px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000004d}.np-toggle-wrap input:checked~.np-toggle-track{background:#4d7cfe;border-color:#4d7cfe}.np-toggle-wrap input:checked~.np-toggle-track:after{background:#fff;transform:translate(16px)}.np-toggle-text{color:#8b93a7;font-size:13px}@keyframes np-spin{to{transform:rotate(360deg)}}.np-spin{animation:.8s linear infinite np-spin}@media (width<=768px){.np-page{padding:16px 14px 40px}.np-topbar{flex-wrap:wrap}.np-topbar-actions{width:100%}.np-btn-cancel,.np-btn-create{flex:1;justify-content:center}.np-grid,.np-grid-3{grid-template-columns:1fr}}.quotes-page{background:var(--bg-base);flex-direction:column;flex:1;gap:14px;min-height:100vh;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}:root{--bg:#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;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000080, 0 1px 4px #0000004d}.works-page{background:var(--bg);flex-direction:column;flex:1;gap:14px;min-height:100vh;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{color:#94a3b8;background:#64748b26}.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);width:520px;max-width:100%;box-shadow:var(--shadow-md), 0 20px 60px #0009;border:1px solid var(--border-md);overflow:hidden}.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:#080b12;width:100%;max-width:900px;min-height:100vh;margin:0 auto;padding:24px 24px 60px}.pd-back-btn{color:#8b93a7;cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;height:32px;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:#e6e9f0;background:#ffffff0d}.pd-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.pd-title{color:#e6e9f0;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 #ffffff12;gap:0;margin-bottom:20px;display:flex}.pd-tab{color:#3d4260;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:#8b93a7}.pd-tab.pd-tab-active{color:#4d7cfe;border-bottom-color:#4d7cfe;font-weight:600}.pd-card{background:#111528;border:1px solid #ffffff12;border-radius:12px;margin-bottom:16px;overflow:hidden}.pd-grid{grid-template-columns:1fr 1fr;display:grid}.pd-field{border-bottom:1px solid #ffffff0a;flex-direction:column;gap:5px;padding:14px 18px;display:flex}.pd-field:nth-child(odd){border-right:1px solid #ffffff0a}.pd-field-label{color:#3d4260;text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.pd-field-value{color:#e6e9f0;font-size:13.5px;font-weight:500}.pd-assignment-block{padding:20px 24px}.pd-assignment-header{color:#e6e9f0;border-bottom:1px solid #ffffff0f;margin-bottom:14px;padding-bottom:10px;font-size:13px;font-weight:600}.pd-assignment-status{color:#3d4260;font-weight:400}.pd-timeline{padding-left:24px;position:relative}.pd-timeline:before{content:"";background:#ffffff14;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:"";background:#8b5cf6;border:2px solid #111528;border-radius:50%;width:10px;height:10px;position:absolute;top:5px;left:-17px;box-shadow:0 0 0 3px #8b5cf633}.pd-timeline-date{color:#3d4260;margin-bottom:4px;font-size:11px}.pd-timeline-status{color:#e6e9f0;margin-bottom:4px;font-size:12.5px;font-weight:600}.pd-timeline-note{color:#8b93a7;font-size:13px;line-height:1.5}.pd-timeline-remarks{color:#8b93a7;background:#ffffff0a;border:1px solid #ffffff12;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:#3d4260;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 #ffffff1a;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 #0006}.pd-expense-table-wrap{overflow-x:auto}.pd-expense-table{border-collapse:collapse;width:100%;font-size:13px}.pd-expense-table thead tr{background:#0d1020;border-bottom:1px solid #ffffff12}.pd-expense-table th{text-align:left;color:#3d4260;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 #ffffff0a;transition:background .1s}.pd-expense-table tbody tr:last-child{border-bottom:none}.pd-expense-table tbody tr:hover{background:#ffffff06}.pd-expense-table td{color:#e6e9f0;vertical-align:middle;padding:12px 14px}.pd-amount-cell{color:#10b981;font-variant-numeric:tabular-nums;font-weight:600}.pd-expense-total{color:#e6e9f0;border-top:1px solid #ffffff12;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 #ffffff1a;border-radius:7px;width:48px;height:48px;transition:box-shadow .15s}.pd-receipt-thumb:hover{box-shadow:0 2px 10px #0006}.pd-loader{color:#8b93a7;justify-content:center;align-items:center;gap:10px;padding:48px 20px;font-size:13px;display:flex}.pd-empty{text-align:center;color:#3d4260;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}}
