:root{--accent: #7C3AED;--accent-secondary: #A78BFA;--accent-blue: #6366F1;--accent-amber: #F59E0B;--accent-purple: #7C3AED;--bg-page: #1E1E2E;--bg-sidebar: #1E1E2E;--bg-card: #282A3A;--bg-hover: #2D2F3F;--bg-active: #323454;--bg-input: #282A3A;--bg-modal-overlay: rgba(0, 0, 0, .6);--text-primary: #E5E7EB;--text-secondary: #9CA3AF;--text-muted: #6B7280;--border-color: #323454;--border-light: #2D2F3F;--danger: #EF4444;--warning: #F59E0B;--success: #34D399;--online-green: #34D399;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .35);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .4);--bubble-outgoing: #282A3A;--bubble-incoming: #2D2F3F;--chat-bg: #1A1A2E;--sidebar-header: #1E1E2E}.theme-light{--accent: #7C3AED;--accent-secondary: #8B5CF6;--bg-page: #F8FAFC;--bg-sidebar: #FFFFFF;--bg-card: #FFFFFF;--bg-hover: #F1F5F9;--bg-active: #E2E8F0;--bg-input: #FFFFFF;--bg-modal-overlay: rgba(0, 0, 0, .3);--text-primary: #0F172A;--text-secondary: #64748B;--text-muted: #94A3B8;--border-color: #E2E8F0;--border-light: #F1F5F9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .08);--bubble-outgoing: #7C3AED;--bubble-incoming: #FFFFFF;--chat-bg: #E8E4F0;--sidebar-header: #FFFFFF}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg-page);color:var(--text-primary);height:100vh;overflow:hidden}#root{height:100vh}.app-container{display:flex;height:100vh;max-width:1600px;margin:0 auto}.sidebar{width:340px;min-width:280px;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;min-height:60px;border-bottom:1px solid var(--border-color)}.sidebar-header h2{font-size:18px;font-weight:700;color:var(--accent);letter-spacing:-.5px}.sidebar-org{font-size:11px;color:var(--text-muted);background:var(--bg-hover);padding:2px 8px;border-radius:6px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-bar{padding:12px 16px;border-bottom:1px solid var(--border-color)}.search-bar input{width:100%;padding:10px 14px 10px 36px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-input);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s;box-shadow:var(--shadow-sm)}.search-bar input:focus{border-color:var(--accent-secondary)}.search-bar input::placeholder{color:var(--text-muted)}.contact-list{flex:1;overflow-y:auto}.contact-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background .1s;gap:12px;border-bottom:1px solid var(--border-light)}.contact-item:hover{background:var(--bg-hover)}.contact-item.active{background:var(--bg-active)}.contact-item .avatar{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.contact-item .contact-info{flex:1;min-width:0}.contact-item .contact-name{font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.contact-item .contact-status{font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:var(--online-green)}.status-dot.away{background:var(--warning)}.status-dot.offline{background:var(--text-muted)}.main-area{flex:1;display:flex;flex-direction:column;background:var(--bg-page);position:relative}.chat-header{padding:12px 20px;display:flex;align-items:center;gap:12px;min-height:60px;border-bottom:1px solid var(--border-color);background:var(--bg-page)}.chat-header .chat-header-info{flex:1}.chat-header .chat-header-info h3{font-size:16px;font-weight:600}.chat-header .chat-header-info p{font-size:13px;color:var(--text-secondary)}.chat-header .chat-header-actions{display:flex;gap:4px}.chat-header .chat-header-actions button{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:6px;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat-header .chat-header-actions button:hover{background:var(--bg-hover)}.messages-area{flex:1;overflow-y:auto;padding:20px 60px;background:var(--chat-bg);background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d1d5db' fill-opacity='0.15'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.message-wrapper{display:flex;margin-bottom:4px}.message-wrapper.incoming{justify-content:flex-start}.message-wrapper.outgoing{justify-content:flex-end}.message-bubble{max-width:65%;padding:8px 14px;border-radius:8px;position:relative;font-size:14.5px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap;box-shadow:var(--shadow-sm)}.message-bubble.incoming{background:var(--bubble-incoming);border-top-left-radius:0;color:var(--text-primary)}.message-bubble.outgoing{background:var(--bubble-outgoing);border-top-right-radius:0;color:#111827}.message-bubble .message-time{font-size:11px;color:var(--text-secondary);text-align:right;margin-top:4px}.message-bubble .message-status{font-size:14px;margin-left:4px}.message-bubble.system{background:transparent;text-align:center;max-width:100%;font-size:12.5px;color:var(--text-secondary);padding:8px}.input-area{padding:12px 20px;display:flex;align-items:center;gap:8px;border-top:1px solid var(--border-color);background:var(--bg-page)}.input-area input{flex:1;padding:10px 16px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-input);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s}.input-area input:focus{border-color:var(--accent-secondary)}.input-area input::placeholder{color:var(--text-muted)}.input-area .send-btn{background:var(--accent);border:none;color:#fff;font-size:18px;cursor:pointer;padding:8px;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background .15s}.input-area .send-btn:hover{background:#6d28d9}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;padding:40px}.empty-state .empty-icon{font-size:64px;margin-bottom:20px;opacity:.3}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-weight:500}.empty-state p{font-size:14px;line-height:1.6}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.badge-success{background:#4caf5026;color:var(--success)}.badge-warning{background:#ffa72626;color:var(--warning)}.badge-danger{background:#ef535026;color:var(--danger)}.badge-info{background:#00a88426;color:var(--teal)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}.stat-card{background:var(--sidebar-header);border-radius:12px;padding:16px;text-align:center}.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--whatsapp-green-lighter)}.stat-card .stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{padding:8px 0;border-bottom:1px solid var(--border-color)}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;text-align:left;transition:all .1s}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-active);color:var(--accent);font-weight:600}.nav-icon{font-size:16px;width:22px;text-align:center}.nav-label{font-weight:500}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:box-shadow .15s,transform .15s;box-shadow:var(--shadow-sm)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-icon{font-size:22px;margin-bottom:8px}.kpi-value{font-size:28px;font-weight:700;color:var(--text-primary)}.kpi-label{font-size:13px;color:var(--text-secondary);margin-top:2px}.kpi-subtitle{font-size:11px;color:var(--text-muted);margin-top:4px}.overview-container{padding:28px 36px;overflow-y:auto;height:100%}.section-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:24px;letter-spacing:-.3px}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.overview-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)}.card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.site-status-list{display:flex;flex-direction:column;gap:2px}.site-status-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .1s}.site-status-item:hover{background:var(--bg-hover)}.site-name{flex:1;font-size:14px;color:var(--text-primary)}.site-count{font-size:12px;color:var(--text-muted)}.role-list{display:flex;flex-direction:column;gap:8px}.role-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-hover);border-radius:8px}.role-name{font-size:14px;color:var(--text-primary);text-transform:capitalize}.role-count{font-size:18px;font-weight:600;color:var(--accent)}.view-container{padding:28px 36px;overflow-y:auto;height:100%}.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px}.view-header h2{font-size:20px;font-weight:700;color:var(--text-primary)}.view-search{padding:8px 14px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-input);color:var(--text-primary);font-size:14px;outline:none;width:280px;transition:border-color .15s}.view-search:focus{border-color:var(--accent-secondary)}.view-search::placeholder{color:var(--text-muted)}.worker-list{display:flex;flex-direction:column}.worker-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-light)}.worker-avatar{width:40px;height:40px;border-radius:10px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.worker-info{flex:1;min-width:0}.worker-name{font-size:15px;font-weight:600;color:var(--text-primary)}.worker-meta{font-size:13px;color:var(--text-secondary)}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.site-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;cursor:pointer;transition:box-shadow .15s,border-color .15s;box-shadow:var(--shadow-sm)}.site-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent)}.site-card-header{display:flex;align-items:flex-start;justify-content:space-between}.site-card-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.site-card-type{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.site-card-hours{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.site-card-workers{font-size:13px;color:var(--accent);font-weight:600}.back-btn{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px}.back-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.empty-note{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;text-decoration:none}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:#6d28d9;box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-active);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{background:none;border:none;color:var(--text-muted);font-size:15px;cursor:pointer;padding:6px;border-radius:6px;transition:all .15s}.icon-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.worker-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.worker-row:hover .worker-actions{opacity:1}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge-success{background:#34d3991f;color:#34d399}.badge-warning{background:#f59e0b1f;color:#fbbf24}.badge-danger{background:#ef44441f;color:#f87171}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-modal-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;width:90%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:20px}.worker-form{display:flex;flex-direction:column;gap:14px}.worker-form label{font-size:13px;color:var(--text-secondary);font-weight:600;margin-bottom:-6px}.worker-form input,.worker-form select{padding:10px 14px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-input);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s}.worker-form input:focus,.worker-form select:focus{border-color:var(--accent-secondary);box-shadow:0 0 0 3px #7c3aed26}.worker-form input::placeholder{color:var(--text-muted)}.form-error{background:#ef444414;color:var(--danger);padding:10px 14px;border-radius:10px;font-size:13px;border:1px solid rgba(239,68,68,.2)}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.incidents-table{display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.incidents-header,.incidents-row{display:grid;grid-template-columns:100px 1fr 2fr 100px 90px 90px;gap:12px;padding:12px 16px;align-items:center;font-size:13px}.incidents-header{background:var(--bg-hover);font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:11px;letter-spacing:.5px}.incidents-row{border-top:1px solid var(--border-light);transition:background .1s}.incidents-row:hover{background:var(--bg-hover)}.col-ref{font-weight:600;color:var(--accent)}.col-desc{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-status,.col-priority{text-transform:capitalize}.col-time{color:var(--text-muted);font-size:12px}.schedules-list{display:flex;flex-direction:column;gap:8px}.schedule-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.schedule-card:hover{box-shadow:var(--shadow-md)}.schedule-time{display:flex;align-items:center;gap:8px;min-width:120px}.schedule-start,.schedule-end{font-size:15px;font-weight:600;color:var(--text-primary)}.schedule-arrow{color:var(--text-muted);font-size:12px}.schedule-info{flex:1}.schedule-worker{font-size:15px;font-weight:600;color:var(--text-primary)}.schedule-site{font-size:13px;color:var(--text-secondary);margin-top:2px}.schedule-status{flex-shrink:0}@media (max-width: 768px){.incidents-header,.incidents-row{grid-template-columns:80px 1fr 80px}.incidents-header .col-site,.incidents-header .col-priority,.incidents-header .col-time,.incidents-row .col-site,.incidents-row .col-priority,.incidents-row .col-time{display:none}}.activity-feed{display:flex;flex-direction:column;gap:2px}.activity-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:13px;transition:background .1s}.activity-item:hover{background:var(--bg-hover)}.activity-icon{font-size:16px;width:24px;text-align:center;flex-shrink:0}.activity-text{flex:1;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-time{font-size:11px;color:var(--text-muted);flex-shrink:0}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.photo-item{border-radius:8px;overflow:hidden;background:var(--bg-hover)}.photo-item img{display:block;max-height:200px;object-fit:cover}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:20px}.admin-login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:400px;text-align:center;box-shadow:var(--shadow-lg)}.admin-login-card h2{font-size:22px;font-weight:700;color:var(--text-primary)}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color)}.theme-toggle{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.theme-toggle:hover{background:var(--bg-active);color:var(--text-primary)}.hamburger{display:none;position:fixed;top:10px;left:10px;z-index:1100;background:var(--sidebar-header);border:none;color:var(--text-primary);font-size:24px;padding:8px 12px;border-radius:8px;cursor:pointer}.sidebar-overlay{display:none}@media (max-width: 1024px){.kpi-row{grid-template-columns:repeat(2,1fr)}.overview-grid{grid-template-columns:1fr}.sites-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (max-width: 768px){.hamburger{display:block}.sidebar{position:fixed;top:0;left:-100%;width:85%;max-width:360px;height:100vh;z-index:1050;transition:left .25s ease}.sidebar.open{left:0}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1040}.app-container{flex-direction:column}.main-area{margin-left:0;padding-top:52px}.overview-container,.view-container{padding:16px}.kpi-row{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-card{padding:14px}.kpi-value{font-size:24px}.overview-grid,.sites-grid{grid-template-columns:1fr}.view-header{flex-direction:column;align-items:stretch;gap:10px}.view-search{width:100%}.messages-area{padding:12px 16px}.message-bubble{max-width:85%}.stats-grid{grid-template-columns:1fr}.modal-content{width:95%;margin:10px}.worker-row{flex-wrap:wrap;gap:8px}.worker-actions{opacity:1;margin-left:52px}}@media (max-width: 480px){.kpi-row{grid-template-columns:1fr 1fr;gap:8px}.kpi-card{padding:12px}.kpi-value{font-size:20px}.kpi-icon{font-size:20px;margin-bottom:4px}.kpi-label{font-size:11px}.overview-container,.view-container{padding:10px}.section-title{font-size:16px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
