.sidebar{z-index:10;border-top:none;border-bottom:none;border-left:none;border-radius:0;flex-direction:column;width:260px;min-height:100vh;display:flex;position:sticky;top:0}.sidebar-header{border-bottom:1px solid var(--border-color);padding:2rem 1.5rem}.sidebar-header h2{color:var(--primary);margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.sidebar-header p{color:var(--text-muted);font-size:.85rem}.sidebar-nav{flex-direction:column;gap:.5rem;padding:1.5rem 1rem;display:flex}.nav-link{color:var(--text-muted);border-radius:var(--radius-md);align-items:center;gap:1rem;padding:.85rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:var(--primary);background:#2563eb0d}.nav-link.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.nav-link.active .icon{color:#fff}.sidebar-footer{border-top:1px solid var(--border-color);margin-top:auto;padding:1.5rem 1rem}.logout-btn{cursor:pointer;width:100%;font-family:inherit;font-size:inherit;background:0 0;border:none}.logout-btn:hover{color:#ef4444;background:#fef2f2}.top-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9;background:#ffffffe6;border-top:none;border-left:none;border-right:none;border-radius:0;justify-content:space-between;align-items:center;height:70px;padding:0 2rem;display:flex;position:sticky;top:0}.search-bar{background:var(--bg-color);border-radius:var(--radius-xl);border:1px solid var(--border-color);align-items:center;width:300px;padding:.5rem 1rem;display:flex}.search-icon{color:var(--text-muted);margin-right:.75rem}.search-bar input{width:100%;color:var(--text-main);background:0 0;border:none;outline:none;font-family:inherit;font-size:.9rem}.header-actions{align-items:center;gap:1.5rem;display:flex}.action-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:flex;position:relative}.action-btn:hover{background:var(--bg-color);color:var(--primary)}.action-btn .badge{background:var(--danger);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.user-profile{cursor:pointer;align-items:center;gap:.75rem;display:flex}.avatar-icon{color:var(--primary)}.user-info{flex-direction:column;display:flex}.user-info .name{font-size:.9rem;font-weight:600}.user-info .role{color:var(--text-muted);font-size:.75rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex;position:fixed;top:0;left:0}.modal-content{border-radius:var(--radius-lg);background:#ffffffe6;flex-direction:column;width:100%;max-width:500px;padding:0;display:flex}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{color:var(--text-main);font-size:1.15rem;font-weight:700}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:background .2s}.close-btn:hover{background:var(--bg-color);color:var(--text-main)}.modal-body{max-height:70vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:1rem;padding:1.25rem 1.5rem;display:flex}.animate-slide-up{animation:.3s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard-container{flex-direction:column;gap:1.5rem;display:flex}.page-header h1{color:var(--text-main);margin-bottom:.25rem;font-size:1.8rem;font-weight:700}.page-header p{color:var(--text-muted)}.top-widgets{grid-template-columns:1fr 2fr;gap:1.5rem;display:grid}.healthy-score-card{flex-direction:column;padding:1.5rem;display:flex}.card-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.card-header h3{font-size:1.1rem;font-weight:600}.status-badge{border-radius:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.text-success{color:var(--success)}.gauge-container{flex:1;justify-content:center;align-items:center;min-height:180px;display:flex;position:relative}.gauge-chart-wrapper{width:100%;max-width:250px;height:130px;position:relative}.gauge-text{flex-direction:column;align-items:center;width:100%;display:flex;position:absolute;bottom:0;left:0}.gauge-text .score{color:var(--success);font-size:2.5rem;font-weight:800;line-height:1}.gauge-text .label{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}.summary-cards-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.summary-card{align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.summary-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:56px;height:56px;display:flex}.summary-info h3{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.summary-info p{color:var(--text-muted);font-size:.9rem}.bottom-widgets{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.chart-card{padding:1.5rem}.filter-select{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-color);outline:none;padding:.4rem 1rem;font-size:.85rem}.chart-wrapper{width:100%;height:250px}.recent-activity{padding:1.5rem}.activity-list{flex-direction:column;gap:1.25rem;display:flex}.activity-item{align-items:flex-start;gap:1rem;display:flex}.activity-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.activity-details .task-name{margin-bottom:.2rem;font-size:.9rem;font-weight:500}.activity-details .task-time{color:var(--text-muted);font-size:.75rem}.teknisi-container{flex-direction:column;display:flex}.d-flex{display:flex}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.mb-4{margin-bottom:1.5rem}.me-2{margin-right:.5rem}.btn-primary-custom{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;padding:.75rem 1.25rem;font-weight:600;transition:background .2s;display:flex}.btn-primary-custom:hover{background:var(--primary-focus)}.filter-bar{justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.search-box{background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-md);flex:1;align-items:center;gap:.75rem;max-width:400px;padding:.5rem 1rem;display:flex}.search-box input{background:0 0;border:none;outline:none;width:100%;font-size:.9rem}.filter-actions{gap:1rem;display:flex}.filter-btn{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;background:#fff;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.sort-select{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#fff;outline:none;padding:.5rem 1rem;font-size:.9rem}.table-container{border-radius:var(--radius-lg);overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);background:#f8fafc;padding:1.25rem 1.5rem;font-size:.85rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-main);vertical-align:middle;padding:1.25rem 1.5rem;font-size:.95rem}.custom-table tr:last-child td{border-bottom:none}.user-info-cell{align-items:center;gap:1rem;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:700;display:flex}.user-name{font-size:.95rem;font-weight:600;display:block}.user-id{color:var(--text-muted);font-size:.8rem;display:block}.location-cell{color:var(--text-muted);align-items:center;gap:.5rem;display:flex}.priority-badge{text-transform:uppercase;border-radius:.25rem;padding:.25rem .6rem;font-size:.75rem;font-weight:700}.priority-badge.high{color:#ef4444;background:#fee2e2}.priority-badge.medium{color:#f59e0b;background:#fef3c7}.priority-badge.low{color:#10b981;background:#dcfce7}.status-pill{border-radius:1rem;align-items:center;gap:.5rem;padding:.4rem .85rem;font-size:.85rem;font-weight:600;display:inline-flex}.status-completed{color:#10b981;background:#d1fae5}.status-progress{color:#2563eb;background:#eff6ff}.status-warning{color:#ef4444;background:#fee2e2}.status-assigned{color:#64748b;background:#f1f5f9}.action-dot-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:background .2s}.action-dot-btn:hover{background:var(--bg-color);color:var(--text-main)}.option-cards{flex-direction:column;gap:1rem;display:flex}.option-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;background:#fff;align-items:center;gap:1.25rem;padding:1.25rem;transition:all .2s;display:flex}.option-card:hover{border-color:var(--primary);background:#f8fafc;transform:translate(5px)}.icon-box{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.bg-success-light{background:#ecfdf5}.option-info{flex-direction:column;display:flex}.option-info strong{color:var(--text-main);margin-bottom:.25rem;font-size:1.05rem}.option-info span{color:var(--text-muted);font-size:.85rem}.tech-form{padding:.5rem 0}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.input-group.full{grid-column:span 2}.input-group label{color:var(--text-main);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.input-group input{border:1px solid var(--border-color);border-radius:var(--radius-md);box-sizing:border-box;width:100%;padding:.75rem 1rem;font-size:.9rem;transition:border-color .2s}.input-group input:focus{border-color:var(--primary);outline:none}.modules-selector{flex-wrap:wrap;gap:.75rem;margin-top:.5rem;display:flex}.module-chip{border:1px solid var(--border-color);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border-radius:2rem;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.module-chip:hover{background:var(--bg-color)}.module-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.modal-footer-custom{justify-content:flex-end;gap:1rem;width:100%;display:flex}.error-alert{color:#ef4444;border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fee2e2;padding:.75rem 1rem;font-size:.85rem}.success-alert{color:#10b981;border-radius:var(--radius-md);background:#f0fdf4;border:1px solid #dcfce7;padding:.75rem 1rem;font-size:.85rem}.mt-3{margin-top:1rem}.mt-1{margin-top:.25rem}.mb-3{margin-bottom:1rem}.text-muted{color:var(--text-muted)}.relative{position:relative}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input-wrapper .search-icon{color:var(--text-muted);position:absolute;left:12px}.search-input-wrapper input{padding-left:2.5rem!important}.spinner-small{border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;position:absolute;right:12px}@keyframes spin{to{transform:rotate(360deg)}}.search-results-dropdown{z-index:100;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:#fff;max-height:200px;margin-top:.5rem;padding:.5rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 10px 25px #0000001a}.search-result-item{border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.75rem;padding:.75rem;transition:background .2s;display:flex}.search-result-item:hover{background:var(--bg-color)}.res-avatar{width:32px;height:32px;color:var(--primary);background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.res-info{flex-direction:column;display:flex}.res-info strong{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;max-width:250px;font-size:.9rem;overflow:hidden}.res-info span{color:var(--text-muted);font-size:.75rem;display:block}.res-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.res-sub-info{flex-direction:column;gap:2px;display:flex}.user-type-tag{color:#64748b;text-transform:uppercase;background:#f1f5f9;border-radius:4px;width:fit-content;margin-top:4px;padding:2px 6px;font-weight:700;display:inline-block;font-size:.65rem!important}.selected-user-badge{color:#10b981;border-radius:var(--radius-md);background:#ecfdf5;align-items:center;gap:.5rem;margin-top:.75rem;padding:.4rem .75rem;font-size:.85rem;font-weight:600;display:inline-flex}.custom-select{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;background:#fff;outline:none;width:100%;padding:.75rem 1rem;font-size:.9rem}.custom-select:focus{border-color:var(--primary)}.cleaning-container{flex-direction:column;display:flex}.cleaning-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.cleaning-card{flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.card-top{justify-content:space-between;align-items:center;display:flex}.status-tag{text-transform:uppercase;border-radius:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700}.status-tag.completed{color:#10b981;background:#d1fae5}.status-tag.in-progress{color:#2563eb;background:#eff6ff}.status-tag.pending{color:#ef4444;background:#fee2e2}.icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.card-body h3{margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.task-desc{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.detail-item{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;display:flex}.card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;display:flex}.crew-info{align-items:center;gap:.75rem;display:flex}.crew-avatar{background:var(--bg-color);width:32px;height:32px;color:var(--primary);border:1px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.check-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;transition:color .2s}.check-btn.checked{color:var(--success)}.check-btn:hover{color:var(--primary)}.ac-monitoring-container{flex-direction:column;display:flex}.ac-stats-row{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.ac-stat-card{align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.ac-stat-card span{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem;display:block}.ac-stat-card h3{font-size:1.5rem;font-weight:700}.unit-info{align-items:center;gap:1rem;display:flex}.unit-name{font-size:.95rem;font-weight:600;display:block}.unit-id{color:var(--text-muted);font-size:.8rem;display:block}.temp-badge{background:var(--bg-color);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:.35rem .75rem;font-size:.9rem;font-weight:700}.load-bar-container{align-items:center;gap:.75rem;display:flex}.load-bar{background:#e2e8f0;border-radius:4px;width:100px;height:8px;position:relative;overflow:hidden}.load-bar:after{content:"";height:100%;width:inherit;background:var(--primary);position:absolute;top:0;left:0}.load-bar-container span{min-width:35px;font-size:.85rem;font-weight:600}.health-status{border-radius:1rem;padding:.35rem .75rem;font-size:.85rem;font-weight:600}.health-status.healthy{color:#10b981;background:#d1fae5}.health-status.warning{color:#f59e0b;background:#fef3c7}.health-status.maintenance{color:#ef4444;background:#fee2e2}.spin{color:var(--primary);animation:3s linear infinite spin}.waste-management-container{flex-direction:column;display:flex}.waste-summary-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.waste-stat-card{align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.waste-icon-box{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:60px;height:60px;display:flex}.bg-primary-light{background:#eff6ff}.waste-stat-card span{color:var(--text-muted);font-size:.9rem}.waste-stat-card h3{margin:.1rem 0;font-size:1.8rem;font-weight:800}.trend{align-items:center;gap:.25rem;font-size:.8rem;font-weight:600;display:flex}.waste-main-row{grid-template-columns:1.5fr 1fr;gap:1.5rem;display:grid}.waste-chart-box,.waste-log-box{padding:1.5rem}.waste-chart-box h3,.waste-log-box h3{margin-bottom:1.5rem;font-size:1.1rem;font-weight:700}.log-list{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.log-item{background:var(--bg-color);border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem;display:flex}.log-time{flex-direction:column;display:flex}.log-time .time{font-size:.9rem;font-weight:700}.log-time .id{color:var(--text-muted);font-size:.75rem}.type-tag{text-transform:uppercase;border-radius:.25rem;padding:.25rem .6rem;font-size:.75rem;font-weight:700}.type-tag.organik{color:#10b981;background:#d1fae5}.type-tag.anorganik{color:#2563eb;background:#eff6ff}.type-tag.b3{color:#ef4444;background:#fee2e2}.btn-outline-custom{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;background:0 0;padding:.75rem;font-weight:600;transition:all .2s}.btn-outline-custom:hover{background:var(--bg-color);color:var(--primary);border-color:var(--primary)}.procurement-container{flex-direction:column;display:flex}.stat-icon.orange{background:linear-gradient(135deg,#fb923c 0%,#f97316 100%)}.stat-icon.green{background:linear-gradient(135deg,#4ade80 0%,#22c55e 100%)}.laundry-container{flex-direction:column;display:flex}.stats-row{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.stat-item{align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.stat-icon{border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.blue{background:linear-gradient(135deg,#60a5fa 0%,#3b82f6 100%)}.stat-icon.purple{background:linear-gradient(135deg,#a78bfa 0%,#8b5cf6 100%)}.stat-icon.yellow{background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%)}.stat-info .label{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem;display:block}.stat-info .value{color:var(--text-main);font-size:1.5rem;font-weight:700;display:block}.user-avatar.blue{color:#2563eb;background:#dbeafe}.text-xs{font-size:.75rem}.font-medium{font-weight:600}.priority-badge.normal{color:#64748b;background:#f1f5f9}.priority-badge.express{color:#ef4444;background:#fee2e2}.priority-badge.special{color:#2563eb;background:#eff6ff}.project-mgmt-container{color:#1e293b;max-width:1400px;margin:0 auto;padding:30px}.page-header{justify-content:space-between;align-items:flex-end;margin-bottom:40px;display:flex}.page-header h1{background:linear-gradient(135deg,#1e293b 0%,#64748b 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:2.5rem;font-weight:800}.project-tabs{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:16px;gap:10px;margin-bottom:30px;padding:8px;display:flex}.tab-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:10px;padding:14px 20px;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.tab-btn:hover{color:#1e293b;background:#fff}.tab-btn.active{background:var(--primary);color:#fff;box-shadow:0 10px 20px -5px #2563eb66}.main-project-card{overflow:hidden;box-shadow:0 10px 30px #0000000d;background:#fff!important;border:1px solid #e2e8f0!important;padding:0!important}.tab-content{padding:30px!important}.glass-inner{color:#1e293b;border-radius:20px;height:100%;padding:25px;transition:all .3s;background:#f8fafc!important;border:1px solid #e2e8f0!important}.glass-inner:hover{border-color:#2563eb4d;transform:translateY(-5px)}.section-label{color:#1e293b;align-items:center;gap:12px;margin-bottom:25px;font-size:1.1rem;font-weight:700;display:flex}.section-label svg{color:var(--primary)}.grid-3{grid-template-columns:repeat(3,1fr);gap:25px;display:grid}.grid-2{grid-template-columns:1fr 1fr;gap:25px;display:grid}.form-control-custom{color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;margin-top:5px;padding:10px;font-size:.85rem}.inline-input-text{color:#1e293b;background:0 0;border:none;border-bottom:1px solid #cbd5e1;outline:none;padding:4px 0;transition:border-color .2s}.inline-input-text:focus{border-color:var(--primary)}.inline-input-text.h3{color:#10b981;font-size:1.5rem;font-weight:700}.inline-input{width:100%;color:var(--primary);text-align:center;background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:2px;font-weight:700}.small-table th{text-align:left;color:#64748b;border-bottom:1px solid #e2e8f0;padding:8px}.small-table td{border-bottom:1px solid #f1f5f9;padding:10px 8px}.progress-mini{background:#e2e8f0;border-radius:10px;height:6px;margin-top:5px;overflow:hidden}.progress-mini .p-bar{background:var(--primary);height:100%}input[type=range]{accent-color:var(--primary);width:100%}.status-badge{border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-block}.status-badge.pending{color:#f59e0b;background:#fff7ed;border:1px solid #ffedd5}.status-badge.approved,.status-badge.ready{color:#10b981;background:#f0fdf4;border:1px solid #dcfce7}.gate-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:15px}.gate-item strong{color:#1e293b}.task-check-item{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:10px;padding:12px;font-size:.9rem;display:flex}.btn-text-primary{color:var(--primary);cursor:pointer;background:0 0;border:none;font-weight:600}.btn-text-danger{color:#ef4444;cursor:pointer;background:0 0;border:none;font-size:1.2rem}@media (width<=1024px){.grid-3,.grid-2{grid-template-columns:1fr}.project-tabs{flex-wrap:wrap}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0f172ab3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content-custom{width:100%;max-width:500px;border-radius:24px!important;padding:30px!important}.btn-close-custom{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;transition:all .2s;display:flex}.btn-close-custom:hover{color:#1e293b;background:#e2e8f0}.btn-primary-custom{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 20px;font-weight:700;transition:all .2s}.btn-secondary-custom{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:12px;padding:12px 20px;font-weight:700}.execution-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;margin-bottom:20px;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.exec-card-body{padding:24px!important}.execution-card:hover{border-color:var(--primary-light);transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a}.execution-card.is-locked{opacity:.7;background:#f8fafc}.exec-progress-track{background:#f1f5f9;border-radius:10px;height:8px;position:relative;overflow:hidden}.exec-progress-fill{background:linear-gradient(90deg, var(--primary), #3b82f6);border-radius:10px;height:100%;transition:width .4s;position:absolute;top:0;left:0}.exec-slider{opacity:0;cursor:pointer;z-index:2;width:100%;height:100%;position:absolute;top:0;left:0}.btn-icon-text{color:#64748b;background:0 0;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;display:flex}.btn-icon-text:hover:not(:disabled){color:var(--primary);border-color:var(--primary-light);background:#f8fafc}.btn-status-action{color:#475569;background:#f1f5f9;border:none;border-radius:8px;padding:6px 16px;font-size:.75rem;font-weight:700;transition:all .2s}.btn-status-action.done{color:#10b981;background:#f0fdf4}.border-top-dashed{border-top:1px dashed #e2e8f0}.status-dot.pulse-green{background:#10b981;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-green;box-shadow:0 0 #10b98166}.search-box-custom{background:#f8fafc;border:1px solid #e2e8f0;transition:all .2s}.search-box-custom:focus-within{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb1a}.tech-item-card{background:#fff;border:1px solid #f1f5f9;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.tech-item-card:hover{border-color:var(--primary-light);background:#f8fafc;transform:translate(4px)}.tech-item-card.is-selected{border-color:var(--primary);background:#eff6ff;box-shadow:0 4px 6px -1px #2563eb1a}.avatar-initials{color:#475569;background:linear-gradient(135deg,#f1f5f9 0%,#e2e8f0 100%);border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.1rem;font-weight:800;transition:all .2s;display:flex}.tech-item-card.is-selected .avatar-initials{background:linear-gradient(135deg, var(--primary) 0%, #1d4ed8 100%);color:#fff}.selection-indicator{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;animation:.2s scaleIn;display:flex}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.exec-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;justify-content:space-between;align-items:center;padding:24px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.exec-summary-card:before{content:"";background:var(--primary);width:4px;height:100%;position:absolute;top:0;left:0}.summary-item{border-right:1px solid #f1f5f9;flex:1;padding:0 20px}.summary-item:last-child{border-right:none}.resource-item-card{background:#f8fafc;border:1px solid #0000;border-radius:16px;margin-bottom:12px;padding:16px;transition:all .3s}.resource-item-card:hover{background:#fff;border-color:#e2e8f0;transform:translate(4px);box-shadow:0 4px 12px #0000000d}.resource-item-card.is-active-vendor{background:#fff1f2;border-color:#fecaca}.resource-item-card.is-active-inv{background:#eff6ff;border-color:#bfdbfe}.icon-box-premium{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;transition:all .3s;display:flex}.bg-white-soft{background:#fff;border:1px solid #f1f5f9}.expense-badge-premium{background:#fff;border-radius:8px;padding:4px 10px;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #0000000d}.custom-checkbox-premium{cursor:pointer;border:2px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex}.is-active-vendor .custom-checkbox-premium{color:#fff;background:#f43f5e;border-color:#f43f5e}.is-active-inv .custom-checkbox-premium{background:var(--primary);border-color:var(--primary);color:#fff}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.queue-card{box-shadow:0 4px 6px -1px #0000000d}.queue-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a;border-color:#cbd5e1!important}.queue-card.active{box-shadow:0 10px 20px -5px #2563eb33}.text-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.inspection-images .img-container{cursor:zoom-in;transition:transform .3s}.inspection-images .img-container:hover{z-index:10;transform:scale(1.02);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a!important}.checklist-item-premium{background:#fff;border:1px solid #e2e8f0;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #00000005}.checklist-item-premium:hover{border-color:var(--primary-light);background:#f8fafc;transform:translate(4px)}.checklist-item-premium.checked{opacity:.8;background:#f0fdf4;border-color:#dcfce7}.checkbox-custom-large{color:#fff;background:#fff;border:2px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.checkbox-custom-large.active{background:#10b981;border-color:#10b981;box-shadow:0 0 0 4px #10b98133}.action-bottom-bar{border-bottom-right-radius:20px;border-bottom-left-radius:20px}.allocation-input{width:100px;color:var(--primary);text-align:center;border:1.5px solid #e2e8f0;border-radius:6px;outline:none;margin:0 5px;padding:2px 5px;font-size:.85rem;font-weight:800;transition:all .2s;background:#fff!important}.allocation-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;background:#eff6ff!important}.allocation-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.allocation-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.login-wrapper{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.login-bg-shapes .shape{filter:blur(80px);z-index:0;opacity:.4;position:absolute}.circle-1{background:var(--primary);width:400px;height:400px;top:-100px;right:-100px}.circle-2{background:#a78bfa;width:300px;height:300px;bottom:-50px;left:-50px}.login-card{z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border:1px solid #ffffff4d;width:100%;max-width:420px;padding:1.5rem 2.5rem 2.5rem;position:relative}.login-main-container{z-index:1;justify-content:center;align-items:center;gap:4rem;width:90%;max-width:1100px;padding:2rem 0;display:flex}.login-info-panel{color:var(--text-main);flex-direction:column;flex:1;gap:2.5rem;display:flex}.info-header h2{background:linear-gradient(135deg, var(--text-main) 0%, var(--primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:1rem 0;font-size:2.5rem;font-weight:800;line-height:1.2}.info-header p{color:var(--text-muted);max-width:500px;font-size:1.1rem}.badge{color:var(--primary);text-transform:uppercase;letter-spacing:1px;background:#2563eb1a;border-radius:2rem;padding:.5rem 1rem;font-size:.8rem;font-weight:700}.info-list{flex-direction:column;gap:1.5rem;display:flex}.info-item{align-items:flex-start;gap:1.25rem;transition:transform .3s;display:flex}.info-item:hover{transform:translate(10px)}.info-icon{color:var(--primary);background:#fff;border-radius:1rem;justify-content:center;align-items:center;padding:.75rem;display:flex;box-shadow:0 4px 6px -1px #0000001a}.info-content h3{margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.info-content p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.info-footer{align-items:center;gap:2rem;padding-top:1rem;display:flex}.stat-item{flex-direction:column;display:flex}.stat-value{color:var(--primary);font-size:1.5rem;font-weight:800}.stat-label{color:var(--text-muted);font-size:.8rem;font-weight:600}.stat-divider{background:var(--border-color);width:1px;height:40px}@media (width<=992px){.login-main-container{flex-direction:column;gap:3rem;padding:3rem 0}.login-info-panel{text-align:center;align-items:center}.info-header p{margin:0 auto}.info-item{text-align:left}.info-footer{justify-content:center}}@media (width<=480px){.login-info-panel{display:none}.login-main-container{padding:1rem}}.login-header{text-align:center;margin-bottom:2.5rem}.logo-icon{justify-content:center;align-items:center;width:120px;height:auto;margin:0 auto 1rem;display:flex}.login-header h1{color:var(--text-main);margin-bottom:.5rem;font-size:1.75rem;font-weight:800}.login-header p{color:var(--text-muted);font-size:.95rem}.login-form .input-group{margin-bottom:1.5rem}.login-form label{color:var(--text-main);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.input-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:all .2s;display:flex}.input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.input-wrapper input{background:0 0;border:none;outline:none;width:100%;font-size:.95rem}.input-wrapper svg{color:var(--text-muted)}.error-msg{color:#ef4444;border-radius:var(--radius-md);background:#fef2f2;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem;font-size:.85rem;font-weight:500;display:flex}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s;display:flex}.login-btn:hover{background:var(--primary-focus);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{text-align:center;color:var(--text-muted);margin-top:2.5rem;font-size:.8rem}.spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.animate-shake{animation:.2s ease-in-out 2 shake}.mt-2{margin-top:.5rem}.mt-4{margin-top:1.5rem}.m-4{margin:1.5rem}.p-4{padding:1.5rem}.p-5{padding:2rem}.text-center{text-align:center}.w-100{width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:root{--primary:#2563eb;--primary-focus:#1d4ed8;--bg-color:#f8fafc;--card-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.app-container{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;display:flex}.page-content{padding:2rem;overflow-y:auto}.glass-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .2s}.glass-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
