body{background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 50%,#7c3aed 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:Inter,sans-serif;display:flex}.login-container{background:#fff;border-radius:20px;width:100%;max-width:440px;padding:48px 40px;box-shadow:0 25px 50px #00000040}.login-logo{text-align:center;margin-bottom:32px}.logo-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;font-size:28px;display:inline-flex}.login-logo h1{color:#111827;font-size:22px;font-weight:700}.login-logo p{color:#6b7280;margin-top:4px;font-size:14px}.login-tabs{background:#f3f4f6;border-radius:10px;gap:4px;margin-bottom:28px;padding:4px;display:flex}.login-tab{text-align:center;cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:8px;flex:1;padding:10px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s}.login-tab.active{color:#2563eb;background:#fff;box-shadow:0 1px 2px #0000000d}.form-control{color:#1f2937;border:1.5px solid #e5e7eb;border-radius:8px;width:100%;padding:10px 14px;font-family:inherit;font-size:14px}.input-icon{position:relative}.input-icon i{color:#9ca3af;font-size:14px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-icon .form-control{padding-left:40px}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{color:#fff;background:#2563eb}.otp-inputs{justify-content:center;gap:10px;margin:20px 0;display:flex}.otp-input{text-align:center;border:1.5px solid #e5e7eb;border-radius:10px;width:48px;height:52px;font-family:inherit;font-size:20px;font-weight:600}.otp-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.alert-info{color:#0e7490;background:#cffafe;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.login-footer{text-align:center;color:#6b7280;margin-top:24px;font-size:13px}.login-footer a{color:#2563eb;font-weight:500;text-decoration:none}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#dbeafe;--secondary:#7c3aed;--success:#16a34a;--success-light:#dcfce7;--warning:#ea580c;--warning-light:#ffedd5;--danger:#dc2626;--danger-light:#fee2e2;--info:#0891b2;--info-light:#cffafe;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--sidebar-width:260px;--header-height:64px;--radius:10px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-100);color:var(--gray-800);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--gray-900);color:#fff;z-index:100;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding:20px;display:flex}.sidebar-header .logo-icon{background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.sidebar-header h2{font-size:15px;font-weight:600;line-height:1.3}.sidebar-header span{color:var(--gray-400);font-size:11px;display:block}.sidebar-nav{padding:12px}.nav-section{margin-bottom:8px}.nav-section-title{text-transform:uppercase;letter-spacing:1px;color:var(--gray-500);padding:12px 12px 6px;font-size:10px;font-weight:600}.nav-item{color:var(--gray-400);cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{background:var(--primary);color:#fff}.nav-item i{text-align:center;width:20px;font-size:15px}.nav-item .badge{background:var(--danger);color:#fff;border-radius:10px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:600}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.top-header{height:var(--header-height);border-bottom:1px solid var(--gray-200);z-index:50;background:#fff;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.search-bar{flex:1;max-width:400px;position:relative}.search-bar input{background:var(--gray-100);width:100%;color:var(--gray-700);border:1.5px solid #0000;border-radius:8px;padding:8px 14px 8px 38px;font-family:inherit;font-size:14px}.search-bar input:focus{border-color:var(--primary);background:#fff;outline:none}.search-bar i{color:var(--gray-400);font-size:14px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.header-icon-btn{width:38px;height:38px;color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex;position:relative}.header-icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.header-icon-btn .notif-dot{background:var(--danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.user-menu{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:4px 8px 4px 4px;display:flex}.user-menu:hover{background:var(--gray-100)}.user-avatar{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex}.user-info .name{color:var(--gray-800);font-size:13px;font-weight:600}.user-info .role{color:var(--gray-500);font-size:11px}.page-content{padding:24px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{color:var(--gray-900);font-size:22px;font-weight:700}.page-header p{color:var(--gray-500);margin-top:2px;font-size:14px}.breadcrumb{color:var(--gray-500);align-items:center;gap:8px;margin-bottom:4px;font-size:13px;display:flex}.breadcrumb a{color:var(--primary);text-decoration:none}.card{border-radius:var(--radius);border:1px solid var(--gray-200);background:#fff;margin-bottom:24px;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h3{font-size:15px;font-weight:600}.card-body{padding:20px}.card-footer{border-top:1px solid var(--gray-100);background:var(--gray-50);padding:12px 20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{border-radius:var(--radius);border:1px solid var(--gray-200);background:#fff;align-items:flex-start;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.stat-icon.blue{background:var(--primary-light);color:var(--primary)}.stat-icon.green{background:var(--success-light);color:var(--success)}.stat-icon.orange{background:var(--warning-light);color:var(--warning)}.stat-icon.red{background:var(--danger-light);color:var(--danger)}.stat-icon.purple{color:var(--secondary);background:#ede9fe}.stat-icon.cyan{background:var(--info-light);color:var(--info)}.stat-info h4{color:var(--gray-500);font-size:13px;font-weight:500}.stat-info .stat-value{color:var(--gray-900);margin-top:4px;font-size:28px;font-weight:700;line-height:1.2}.stat-info .stat-change{align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}thead{background:var(--gray-50)}th{text-align:left;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-200);white-space:nowrap;padding:10px 16px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:12px 16px}tr:hover td{background:var(--gray-50)}.status-badge{border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-badge.completed{background:var(--success-light);color:var(--success)}.status-badge.ongoing{background:var(--primary-light);color:var(--primary)}.status-badge.planned{background:var(--warning-light);color:var(--warning)}.status-badge.inactive{background:var(--gray-100);color:var(--gray-500)}.status-badge .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.action-btns{gap:4px;display:flex}.action-btn{border:1px solid var(--gray-200);cursor:pointer;width:30px;height:30px;color:var(--gray-500);background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:12px;display:flex}.action-btn:hover{background:var(--gray-50);color:var(--primary);border-color:var(--primary)}.action-btn.delete:hover{color:var(--danger);border-color:var(--danger)}.grid-2{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.progress-bar-track{background:var(--gray-100);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{border-radius:4px;height:100%}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:24px;display:grid}.photo-card{border:1px solid var(--gray-200);background:#fff;border-radius:8px;overflow:hidden}.photo-placeholder{background:var(--gray-100);height:150px;color:var(--gray-400);justify-content:center;align-items:center;font-size:36px;display:flex}.photo-info{padding:10px 12px}.photo-info .stage{text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.photo-info .stage.before{color:var(--warning)}.photo-info .stage.progress{color:var(--primary)}.photo-info .stage.completed{color:var(--success)}.photo-info .meta{color:var(--gray-400);margin-top:4px;font-size:11px}.upload-area{border:2px dashed var(--gray-300);text-align:center;background:var(--gray-50);cursor:pointer;border-radius:12px;padding:40px}.upload-area:hover{border-color:var(--primary);background:var(--primary-light)}.upload-area i{color:var(--gray-400);margin-bottom:12px;font-size:40px}.upload-area p{color:var(--gray-600);font-size:14px}.upload-area span{color:var(--primary);font-weight:500}.timeline{padding-left:28px;position:relative}.timeline:before{content:"";background:var(--gray-200);width:2px;position:absolute;top:4px;bottom:4px;left:8px}.timeline-item{margin-bottom:20px;position:relative}.timeline-item:before{content:"";border:2px solid var(--primary);background:#fff;border-radius:50%;width:12px;height:12px;position:absolute;top:6px;left:-24px}.timeline-item.completed:before{background:var(--success);border-color:var(--success)}.timeline-item .time{color:var(--gray-400);margin-bottom:2px;font-size:12px}.timeline-item .desc{color:var(--gray-700);font-size:14px}.filters-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-select{border:1.5px solid var(--gray-200);color:var(--gray-700);cursor:pointer;background:#fff;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:13px}.tab-nav{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:20px;display:flex}.tab-btn{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.bar-chart{align-items:flex-end;gap:16px;height:200px;padding:20px 0;display:flex}.bar-group{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.bar{border-radius:6px 6px 0 0;width:100%;max-width:40px}.bar-label{color:var(--gray-500);font-size:11px}.chart-legend{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:16px;display:flex}.legend-item{color:var(--gray-600);align-items:center;gap:6px;font-size:13px;display:flex}.legend-dot{border-radius:3px;width:10px;height:10px}.activity-list{list-style:none}.activity-item{border-bottom:1px solid var(--gray-100);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;display:flex}.activity-text{color:var(--gray-700);font-size:13px}.activity-text strong{color:var(--gray-900)}.activity-time{color:var(--gray-400);margin-top:2px;font-size:11px}.map-placeholder{background:var(--gray-100);height:200px;color:var(--gray-400);border:1px solid var(--gray-200);border-radius:8px;justify-content:center;align-items:center;display:flex}.map-placeholder i{margin-right:8px;font-size:32px}.report-card{border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;background:#fff;align-items:center;gap:16px;margin-bottom:12px;padding:20px;transition:all .2s;display:flex}.report-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.report-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.report-info h4{color:var(--gray-800);font-size:15px;font-weight:600}.report-info p{color:var(--gray-500);margin-top:2px;font-size:13px}.report-export{gap:6px;margin-left:auto;display:flex}.alert{border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.alert-info{background:var(--info-light);color:#0e7490}.alert-success{background:var(--success-light);color:#15803d}.alert-warning{background:var(--warning-light);color:#c2410c}.btn{cursor:pointer;border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{color:var(--gray-700);border-color:var(--gray-200);background:#fff}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:12px 24px;font-size:15px}.pagination{justify-content:center;align-items:center;gap:4px;padding:16px 0;display:flex}.page-btn{border:1px solid var(--gray-200);cursor:pointer;width:34px;height:34px;color:var(--gray-600);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.page-btn:hover{background:var(--gray-50)}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.form-group{margin-bottom:20px}.form-group label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-control{border:1.5px solid var(--gray-200);width:100%;color:var(--gray-800);background:#fff;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-control::placeholder{color:var(--gray-400)}textarea.form-control{resize:vertical}@media (width<=768px){.sidebar{transition:all .3s;position:fixed;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.stats-grid{grid-template-columns:1fr 1fr}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-content{padding:16px}}
