:root{--primary: #1976D2;--primary-dark: #1565C0;--secondary: #388E3C;--accent: #FFA000;--background: #F5F5F5;--surface: #FFFFFF;--text: #212121;--text-secondary: #757575;--border: #E0E0E0;--error: #D32F2F;--success: #388E3C;--shadow: 0 2px 8px rgba(0,0,0,.1);--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:var(--background);color:var(--text)}a{color:var(--primary);text-decoration:none}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}.sidebar-logo{font-size:1.25rem;font-weight:700;color:var(--primary)}.sidebar-nav{flex:1;padding:16px 0}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:var(--text-secondary);transition:all .2s}.nav-item:hover{background:var(--background);color:var(--text)}.nav-item.active{background:#1976d21a;color:var(--primary);border-right:3px solid var(--primary)}.main-content{flex:1;display:flex;flex-direction:column}.page-header{padding:20px 24px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.page-title{font-size:1.5rem;font-weight:600}.page-content{flex:1;padding:24px}.map-container{display:flex;height:calc(100vh - 80px)}.map-sidebar{width:380px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.map-search{padding:16px;border-bottom:1px solid var(--border)}.search-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;outline:none}.search-input:focus{border-color:var(--primary)}.filter-row{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.filter-select{flex:1;min-width:140px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem}.filter-chip{padding:6px 12px;border-radius:20px;font-size:.8rem;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary)}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.location-list{flex:1;overflow-y:auto;padding:12px}.location-item{padding:14px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:10px;cursor:pointer;transition:all .2s}.location-item:hover{border-color:var(--primary);box-shadow:var(--shadow)}.location-category-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;margin-bottom:6px}.location-name{font-weight:600;margin-bottom:4px}.location-address{font-size:.85rem;color:var(--text-secondary)}.map-wrapper{flex:1;position:relative}.map-wrapper>div{width:100%;height:100%}.map-layout{display:flex;height:calc(100vh + -0px)}.map-sidebar-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.map-sidebar-title{font-size:1rem;font-weight:600;flex:1}.map-sidebar-count{font-size:.8rem;color:var(--text-secondary);background:var(--background);padding:2px 8px;border-radius:12px}.map-sidebar-list{flex:1;overflow-y:auto}.map-sidebar-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.map-sidebar-item:hover{background:var(--background)}.map-sidebar-item.active{background:#14b8a614;border-left:3px solid #14b8a6}.map-sidebar-item-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.map-sidebar-item-badge{font-size:.75rem;color:#14b8a6;background:#14b8a61f;padding:1px 6px;border-radius:4px}.map-sidebar-item-sub{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-secondary);margin-top:3px}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:500;margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none}.form-textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-size:.95rem;cursor:pointer;border:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--error);color:#fff}.btn-sm{padding:6px 12px;font-size:.85rem}.table-wrapper{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border)}.table th{background:var(--background);font-weight:600;font-size:.875rem;color:var(--text-secondary)}.table-actions{display:flex;gap:8px}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--surface);border-radius:12px;padding:24px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary)}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px}.alert-error{background:#d32f2f1a;color:var(--error)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-state-icon{font-size:3rem;margin-bottom:12px}.loading{display:flex;align-items:center;justify-content:center;padding:40px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-chatbox-root{position:fixed;right:20px;bottom:20px;z-index:1200}.ai-chatbox-fab{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),#42A5F5);color:#fff;border:none;border-radius:999px;padding:12px 16px;box-shadow:0 10px 24px #1976d259;cursor:pointer;font-weight:600}.ai-chatbox-panel{width:360px;max-height:70vh;display:flex;flex-direction:column;gap:10px;margin-bottom:12px;padding:14px}.ai-chatbox-header{display:flex;justify-content:space-between;align-items:center}.ai-chatbox-title{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--primary)}.ai-chatbox-close{background:none;border:none;color:var(--text-secondary);cursor:pointer}.ai-chatbox-suggestions{display:flex;gap:8px;flex-wrap:wrap}.ai-suggestion-chip{border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-secondary);font-size:12px;padding:6px 10px;cursor:pointer}.ai-chatbox-messages{background:var(--background);border:1px solid var(--border);border-radius:10px;padding:10px;min-height:220px;max-height:38vh;overflow-y:auto}.ai-msg-row{margin-bottom:8px;display:flex;flex-direction:column}.ai-msg-row.user{align-items:flex-end}.ai-msg-row.assistant{align-items:flex-start}.ai-msg-bubble{max-width:88%;border-radius:10px;padding:8px 10px;font-size:13px;line-height:1.4;white-space:pre-wrap}.ai-msg-bubble.user{background:var(--primary);color:#fff}.ai-msg-bubble.assistant{background:#fff;border:1px solid var(--border)}.ai-msg-time{margin-top:2px;font-size:11px;color:var(--text-secondary)}.ai-chatbox-input{display:flex;gap:8px}.ai-block-text{margin:4px 0;line-height:1.5}.ai-block-number{display:flex;flex-direction:column;align-items:center;padding:12px;background:var(--background);border-radius:8px}.ai-number-value{font-size:2rem;font-weight:700;color:var(--primary)}.ai-number-unit{font-size:.75rem;color:#6b7280;margin-top:2px}.ai-number-label{font-size:.875rem;color:#374151;margin-top:4px}.ai-block-card{background:var(--background);border-radius:8px;padding:12px}.ai-card-title{font-weight:600;margin-bottom:8px;font-size:.875rem;color:#374151}.ai-card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.ai-card-item{display:flex;flex-direction:column}.ai-card-item-label{font-size:.75rem;color:#6b7280}.ai-card-item-value{font-size:1.125rem;font-weight:600}.ai-block-chart{padding:8px 0}.ai-chart-title{font-size:.8rem;font-weight:600;color:#374151;margin-bottom:8px}.ai-bar-container{display:flex;flex-direction:column;gap:6px}.ai-bar-row{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:8px}.ai-bar-label{font-size:.75rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-bar-track{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.ai-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.ai-bar-value{font-size:.75rem;font-weight:600;text-align:right;color:#374151}.ai-donut-layout{display:flex;align-items:center;gap:16px}.ai-donut-svg{width:120px;height:120px;flex-shrink:0}.ai-donut-slice{transition:stroke-dashoffset .6s ease}.ai-donut-legend{display:flex;flex-direction:column;gap:4px}.ai-donut-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem}.ai-donut-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ai-donut-label{color:#374151;flex:1}.ai-donut-val{font-weight:600;color:#111827}.ai-table-scroll{overflow-x:auto}.ai-table{width:100%;border-collapse:collapse;font-size:.8rem}.ai-table th,.ai-table td{padding:6px 8px;text-align:left;border-bottom:1px solid #e5e7eb}.ai-table th{font-weight:600;color:#374151;background:var(--background)}.ai-block-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ai-inline-suggestion{font-size:.75rem;padding:4px 10px;background:#eff6ff;color:#3b82f6;border-radius:20px;border:1px solid #bfdbfe;cursor:default}.ai-location-list-title{font-weight:600;font-size:.875rem;margin-bottom:8px;color:#374151}.ai-location-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.ai-location-item{display:flex;align-items:center;gap:8px;font-size:.8rem}.ai-location-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ai-location-dot.active{background:#22c55e}.ai-location-dot.inactive{background:#ef4444}.ai-location-name{font-weight:500;color:#111827}.ai-location-addr{color:#6b7280}.ai-block-error{padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem}.ai-msg-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-msg-avatar.user{background:var(--primary);color:#fff}.ai-msg-avatar.assistant{background:var(--background);color:var(--text-secondary)}.ai-msg-row{display:flex;gap:8px;margin-bottom:12px;align-items:flex-start}.ai-msg-row.user{flex-direction:row-reverse}.ai-msg-bubble.assistant{display:flex;flex-direction:column;gap:6px}.ai-typing-dots{display:flex;gap:4px;padding:4px 0}.ai-typing-dots span{width:6px;height:6px;background:#9ca3af;border-radius:50%;animation:ai-typing 1.2s infinite}.ai-typing-dots span:nth-child(2){animation-delay:.2s}.ai-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes ai-typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.region-split-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.region-panel{display:flex;flex-direction:column;gap:12px}.region-panel-header{display:flex;flex-direction:column;gap:8px}.region-panel-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;color:var(--text)}.region-badge{background:#1976d21a;color:var(--primary);padding:1px 8px;border-radius:12px;font-size:.75em;font-weight:600}.region-badge-province{background:#1976d226;color:var(--primary-dark)}.region-search-row{position:relative}.region-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.region-search-input{padding-left:32px!important}.region-table-wrapper{overflow:hidden}.region-table-wrapper .table tbody tr{cursor:pointer}.stats-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stats-kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;align-items:center;gap:4px}.stats-kpi-value{font-size:2rem;font-weight:700;line-height:1}.stats-kpi-label{font-size:.8rem;color:var(--text-secondary);text-align:center}.stats-kpi-sub{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.stats-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.stats-chart-card{min-height:300px}.stats-chart-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:16px}.stats-donut-layout{display:flex;align-items:center;gap:24px}.stats-donut-svg{width:160px;height:160px;flex-shrink:0}.stats-donut-seg{transition:stroke-dashoffset .6s ease}.stats-donut-legend{display:flex;flex-direction:column;gap:10px;flex:1}.stats-donut-legend-item{display:flex;align-items:center;gap:8px;font-size:.875rem}.stats-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.stats-donut-legend-label{flex:1;color:var(--text)}.stats-donut-legend-val{font-weight:600;color:var(--text)}.stats-donut-legend-pct{color:var(--text-secondary);font-size:.8em;width:38px;text-align:right}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1976d2,#0d47a1)}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:2rem;margin-bottom:8px}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.login-form .form-group{margin-bottom:20px}.login-form .form-label{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.875rem}.login-form .form-error{background:#d32f2f1a;color:var(--error);padding:10px 14px;border-radius:var(--radius);margin-bottom:16px;font-size:.875rem}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;border-radius:var(--radius);cursor:pointer;text-align:left;transition:background .15s}.user-menu-trigger:hover{background:var(--background)}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{display:block;font-weight:600;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{display:flex;align-items:center;gap:3px;font-size:.75rem;color:var(--text-secondary);margin-top:2px}.chevron{color:var(--text-secondary);transition:transform .2s}.chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 -4px 20px #0000001f;padding:10px;z-index:100}.dropdown-item-label{font-size:.8rem;color:var(--text-secondary);padding:4px 6px;display:flex;align-items:center;gap:6px}.role-badge{font-size:.7rem;padding:1px 6px;border-radius:4px;font-weight:600}.role-badge.role-admin{background:#1976d21a;color:var(--primary)}.role-badge.role-user{background:#388e3c1a;color:var(--secondary)}.role-badge.user-admin{background:#d32f2f1a;color:var(--error)}.dropdown-logout{display:flex;align-items:center;gap:6px;width:100%;padding:8px 6px;border:none;background:none;color:var(--error);cursor:pointer;font-size:.875rem;border-radius:4px;margin-top:6px}.dropdown-logout:hover{background:#d32f2f14}.nav-divider{height:1px;background:var(--border);margin:12px 20px}.nav-section-label{padding:8px 20px 4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.user-admin-badges{display:flex;gap:6px;flex-wrap:wrap}.status-badge{font-size:.75rem;padding:2px 8px;border-radius:12px;font-weight:600}.status-active{background:#388e3c1f;color:var(--secondary)}.status-inactive{background:#d32f2f1a;color:var(--error)}.role-admin-badge{background:#1976d21a;color:var(--primary)}.role-user-badge{background:#388e3c1a;color:var(--secondary)}.role-badge.role-manager{background:#f57c001a;color:#f57c00}.stats-bar-chart{display:flex;flex-direction:column;gap:8px}.stats-bar-row{display:grid;grid-template-columns:90px 1fr 40px;align-items:center;gap:10px}.stats-bar-label{font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-bar-track{height:14px;background:var(--background);border-radius:7px;overflow:hidden}.stats-bar-fill{height:100%;border-radius:7px;transition:width .6s ease}.stats-bar-val{font-size:.82rem;font-weight:600;text-align:right;color:var(--text)}.stats-table-scroll{overflow-x:auto}.stats-table{width:100%;border-collapse:collapse;font-size:.875rem}.stats-table th,.stats-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}.stats-table th{font-weight:600;font-size:.8rem;color:var(--text-secondary);background:var(--background)}.stats-table tbody tr:hover{background:#1976d20a}@media (max-width: 768px){.sidebar{width:60px}.sidebar-logo,.nav-label{display:none}.nav-item{justify-content:center;padding:14px}.form-row{grid-template-columns:1fr}.ai-chatbox-root{right:10px;bottom:10px}.ai-chatbox-panel{width:min(92vw,360px)}}
