:root{--color-primary: #1B3A6B;--color-primary-light: #2C5391;--color-primary-dark: #122A4E;--color-accent: #3FA796;--color-accent-dark: #2E8377;--color-amber: #E8A33D;--color-amber-dark: #C9852A;--color-danger: #D64545;--color-danger-bg: #FBEAEA;--color-warning: #E8A33D;--color-warning-bg: #FCF3E3;--color-info: #2C6BC0;--color-info-bg: #E8F0FB;--color-success: #2E9E6B;--color-success-bg: #E7F6EF;--color-neutral: #6B7686;--color-neutral-bg: #EBEDF1;--color-bg: #F4F6F9;--color-surface: #FFFFFF;--color-surface-alt: #F9FAFC;--color-border: #E2E6ED;--color-border-strong: #C9D1DE;--color-text: #1E2733;--color-text-muted: #5B6675;--color-text-faint: #8B95A3;--color-text-inverse: #FFFFFF;--font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-md: .9375rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-xxl: 1.75rem;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(18, 42, 78, .06), 0 1px 1px rgba(18, 42, 78, .04);--shadow-md: 0 4px 10px rgba(18, 42, 78, .08), 0 1px 3px rgba(18, 42, 78, .06);--shadow-lg: 0 10px 30px rgba(18, 42, 78, .14);--sidebar-width: 250px;--header-height: 64px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-md);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0 0 var(--space-sm) 0;font-weight:600;color:var(--color-text);letter-spacing:-.01em}p{margin:0 0 var(--space-sm) 0}a{color:var(--color-primary);text-decoration:none}.app-shell{display:flex;height:100vh;width:100vw;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.app-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.page-header h1{font-size:var(--font-size-xxl)}.page-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:-6px}.page-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:var(--space-lg)}.card-title{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--space-md);color:var(--color-text)}.chart-empty-state{display:flex;align-items:center;justify-content:center;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);background:var(--color-bg-muted, #F4F6F9);border-radius:var(--radius-md, 10px)}.card-grid{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.card-grid>*{flex:1 1 220px;max-width:320px}.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-lg)}@media (max-width: 1100px){.section-grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:var(--font-size-sm);font-weight:600;padding:9px 16px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-secondary{background:var(--color-surface);color:var(--color-primary);border-color:var(--color-border-strong)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-alt)}.btn-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger-bg)}.btn-accent{background:var(--color-accent);color:var(--color-text-inverse)}.btn-accent:hover:not(:disabled){background:var(--color-accent-dark)}.btn-sm{padding:5px 10px;font-size:var(--font-size-xs)}.btn-icon{padding:6px 8px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--color-surface-alt);color:var(--color-text)}.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--space-md)}.form-field label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.form-field input,.form-field select,.form-field textarea{font-family:inherit;font-size:var(--font-size-md);padding:9px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1b3a6b1f}.form-field .field-hint{font-size:var(--font-size-xs);color:var(--color-danger)}.password-input-wrapper{position:relative;display:flex}.password-input-wrapper input{width:100%;padding-right:40px}.password-toggle-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;font-size:16px;line-height:1;padding:6px 8px;border-radius:var(--radius-sm);color:var(--color-text-muted)}.password-toggle-btn:hover{background:var(--color-bg-muted, #F4F6F9)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 var(--space-md)}.form-grid .full-row{grid-column:1 / -1}@media (max-width: 700px){.form-grid{grid-template-columns:1fr}}.table-toolbar{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-md)}.table-toolbar input,.table-toolbar select{font-family:inherit;font-size:var(--font-size-sm);padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface)}table.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}table.data-table thead th{text-align:left;padding:10px 14px;background:var(--color-surface-alt);color:var(--color-text-muted);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}table.data-table thead th:hover{color:var(--color-primary)}table.data-table tbody td{padding:10px 14px;border-bottom:1px solid var(--color-border);color:var(--color-text);white-space:nowrap}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tbody tr:hover{background:var(--color-surface-alt)}.table-empty{padding:var(--space-xl);text-align:center;color:var(--color-text-faint)}.cell-muted{color:var(--color-text-faint)}.maps-link{color:var(--color-primary);font-weight:600;white-space:nowrap;text-decoration:none}.maps-link:hover{text-decoration:underline}.table-actions{display:flex;gap:4px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.02em;white-space:nowrap}.badge-red{background:var(--color-danger-bg);color:var(--color-danger)}.badge-amber{background:var(--color-warning-bg);color:var(--color-amber-dark)}.badge-blue{background:var(--color-info-bg);color:var(--color-info)}.badge-green{background:var(--color-success-bg);color:var(--color-success)}.badge-gray{background:var(--color-neutral-bg);color:var(--color-neutral)}.kpi-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-primary)}.kpi-card.kpi-danger:before{background:var(--color-danger)}.kpi-card.kpi-accent:before{background:var(--color-accent)}.kpi-card.kpi-amber:before{background:var(--color-amber)}.kpi-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.kpi-value{font-size:var(--font-size-xxl);font-weight:700;color:var(--color-text)}.kpi-value.kpi-danger-text{color:var(--color-danger)}.kpi-footnote{font-size:var(--font-size-xs);color:var(--color-text-faint)}.alert-banner{display:flex;align-items:center;gap:var(--space-sm);background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(214,69,69,.3);border-radius:var(--radius-md);padding:12px 16px;font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-md)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#122a4e73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.modal-box{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:640px;max-height:88vh;display:flex;flex-direction:column}.modal-box.modal-lg{max-width:860px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:var(--font-size-lg)}.modal-body{padding:var(--space-lg);overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.auth-screen{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--color-primary-dark) 0%,var(--color-primary) 55%,var(--color-primary-light) 100%)}.auth-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;padding:var(--space-xl)}.auth-brand{text-align:center;margin-bottom:var(--space-lg)}.auth-brand .brand-mark{width:56px;height:56px;border-radius:14px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;margin:0 auto 12px;overflow:hidden}.brand-mark .brand-logo{width:68%;height:68%;object-fit:contain}.auth-brand h1{font-size:var(--font-size-lg);margin-bottom:2px}.auth-brand p{color:var(--color-text-muted);font-size:var(--font-size-sm)}.auth-error{background:var(--color-danger-bg);color:var(--color-danger);border-radius:var(--radius-sm);padding:10px 12px;font-size:var(--font-size-sm);margin-bottom:var(--space-md);font-weight:600}.auth-success{background:var(--color-success-bg);color:var(--color-success);border-radius:var(--radius-sm);padding:10px 12px;font-size:var(--font-size-sm);margin-bottom:var(--space-md);font-weight:600}.auth-footer-link{text-align:center;margin-top:var(--space-md);font-size:var(--font-size-sm)}.sidebar{width:var(--sidebar-width);background:var(--color-primary-dark);color:#fff;display:flex;flex-direction:column;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:18px var(--space-md);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand .brand-mark{width:36px;height:36px;border-radius:9px;background:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#fff;flex-shrink:0;overflow:hidden}.sidebar-brand-text{line-height:1.2}.sidebar-brand-text strong{display:block;font-size:var(--font-size-sm);font-weight:700}.sidebar-brand-text span{font-size:11px;color:#ffffff8c}.sidebar-nav{flex:1;padding:var(--space-md) var(--space-sm);display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);color:#ffffffbf;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.sidebar-link:hover{background:#ffffff12;color:#fff}.sidebar-link.active{background:var(--color-accent);color:#fff;font-weight:600}.sidebar-link .nav-icon{width:18px;text-align:center;flex-shrink:0}.sidebar-footer{padding:var(--space-md);border-top:1px solid rgba(255,255,255,.1)}.sidebar-config-btn{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:1px solid rgba(255,255,255,.15);color:#ffffffbf;padding:8px 12px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer}.sidebar-config-btn:hover{background:#ffffff14;color:#fff}.app-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);flex-shrink:0}.header-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.header-user{display:flex;align-items:center;gap:var(--space-md)}.header-user-info{text-align:right;line-height:1.25}.header-user-info strong{display:block;font-size:var(--font-size-sm);color:var(--color-text)}.header-user-info span{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:capitalize}.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.tabs-bar{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg)}.tab-item{padding:10px 16px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent}.tab-item:hover{color:var(--color-primary)}.tab-item.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pipeline-board{display:grid;grid-template-columns:repeat(6,minmax(180px,1fr));gap:var(--space-md);overflow-x:auto}.pipeline-column{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);min-height:160px}.pipeline-column-header{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-sm);display:flex;justify-content:space-between;align-items:center}.pipeline-count{background:var(--color-primary);color:#fff;border-radius:999px;font-size:10px;padding:1px 7px}.pipeline-value{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-sm)}.pipeline-card{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 10px;font-size:var(--font-size-xs);margin-bottom:6px;cursor:pointer}.pipeline-card:hover{border-color:var(--color-primary)}.pipeline-card strong{display:block;font-size:var(--font-size-sm);margin-bottom:2px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);font-size:var(--font-size-sm)}.spinner{width:22px;height:22px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--color-primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scroll-x{overflow-x:auto}
