@import"https://fonts.googleapis.com/css2?family=Urbanist:wght@400;500;600;700&display=swap";:root{--color-primary: #76FB91;--color-primary-light: #EAFEF0;--color-primary-dark: #166534;--color-black: #000000;--color-white: #FFFFFF;--color-gray-100: #F7F7F8;--color-gray-200: #EBEBEB;--color-gray-300: #D1D1D6;--color-gray-400: #A1A1AA;--color-gray-500: #71717A;--color-error: #EF4444;--color-error-light: #FEF2F2;--color-error-dark: #991B1B;--color-warning: #F59E0B;--color-warning-light: #FFFBEB;--color-warning-dark: #92400E;--color-info: #3B82F6;--color-info-light: #EFF6FF;--color-info-dark: #1E40AF;--gradient-decorative: linear-gradient(180deg, #76FB91 0%, rgba(118, 251, 145, 0) 100%);--gradient-page-bg: linear-gradient(180deg, #F7F7F8 0%, #FFFFFF 100%);--gradient-gauge: linear-gradient(90deg, #76FB91 0%, rgba(118, 251, 145, .3) 100%);--font-family: "Urbanist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-caption: 12px;--font-size-small: 14px;--font-size-body: 16px;--font-size-h3: 18px;--font-size-h2: 22px;--font-size-h1: 28px;--font-size-display: 36px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.15;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 100px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .08);--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--sidebar-width-collapsed: 64px;--sidebar-width-expanded: 240px;--header-height: 72px;--content-max-width: 1440px;--content-padding: 32px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-black);background-color:var(--color-gray-100);min-height:100vh}#root{min-height:100vh}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{font-family:var(--font-family);cursor:pointer;border:none;background:none;padding:0}input,select,textarea{font-family:var(--font-family);font-size:var(--font-size-small)}table{border-collapse:collapse}h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);line-height:32px}h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);line-height:28px}h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);line-height:24px}.amount{font-variant-numeric:tabular-nums;font-weight:var(--font-weight-bold)}.card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-6);transition:border-color var(--duration-normal) var(--ease-default)}.card:hover{border-color:var(--color-gray-300)}.card-alert{background:var(--color-white);border:1px solid var(--color-gray-200);border-left:4px solid var(--color-error);border-radius:var(--radius-lg);padding:var(--space-6)}.card-alert.warning{border-left-color:var(--color-warning)}.btn-primary{background:var(--color-black);color:var(--color-white);border:none;border-radius:var(--radius-full);padding:10px 24px;font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);height:40px;cursor:pointer;transition:opacity var(--duration-normal) var(--ease-default);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--color-white);color:var(--color-black);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);padding:10px 24px;font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);height:40px;cursor:pointer;transition:border-color var(--duration-normal) var(--ease-default);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-secondary:hover{border-color:var(--color-black)}.btn-accent{background:var(--color-primary);color:var(--color-black);border:none;border-radius:var(--radius-full);padding:10px 24px;font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);height:40px;cursor:pointer;transition:opacity var(--duration-normal) var(--ease-default);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-accent:hover{opacity:.85}.btn-danger{background:var(--color-white);color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--radius-full);padding:10px 24px;font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);height:40px;cursor:pointer;transition:background var(--duration-normal) var(--ease-default);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-danger:hover{background:var(--color-error-light)}.btn-icon{width:40px;height:40px;border-radius:var(--radius-md);background:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-gray-400);transition:background var(--duration-normal) var(--ease-default),color var(--duration-normal) var(--ease-default)}.btn-icon:hover{background:var(--color-gray-100);color:var(--color-black)}.btn-icon.active{background:#76fb9126;color:var(--color-primary)}.btn-sm{height:32px;padding:6px 16px;font-size:var(--font-size-caption)}.btn-lg{height:48px;padding:12px 32px;font-size:var(--font-size-body)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);line-height:16px;white-space:nowrap}.badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.badge-competitive{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-competitive .badge-dot{background:var(--color-primary)}.badge-challenger{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-challenger .badge-dot{background:var(--color-warning)}.badge-out_of_range{background:var(--color-error-light);color:var(--color-error-dark)}.badge-out_of_range .badge-dot{background:var(--color-error)}.badge-success{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-success .badge-dot{background:var(--color-primary)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-error .badge-dot{background:var(--color-error)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-warning .badge-dot{background:var(--color-warning)}.badge-pending{background:var(--color-gray-100);color:var(--color-gray-500)}.badge-pending .badge-dot{background:var(--color-gray-300)}.badge-applied{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-applied .badge-dot{background:var(--color-primary)}.badge-approved{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-approved .badge-dot{background:var(--color-primary)}.badge-rejected{background:var(--color-error-light);color:var(--color-error-dark)}.badge-rejected .badge-dot{background:var(--color-error)}.badge-neutral{background:var(--color-gray-100);color:var(--color-gray-500)}.table-container{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);overflow:hidden}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:12px 16px;font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em;background:var(--color-gray-100);border-bottom:1px solid var(--color-gray-200)}.table td{padding:14px 16px;font-size:var(--font-size-small);color:var(--color-black);border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#fafafa}.input{width:100%;height:40px;padding:0 16px;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-small);color:var(--color-black);transition:border-color var(--duration-normal) var(--ease-default)}.input::placeholder{color:var(--color-gray-400)}.input:focus{outline:none;border-color:var(--color-black)}.input:disabled{background:var(--color-gray-100);color:var(--color-gray-400);cursor:not-allowed}.input.error{border-color:var(--color-error)}.label{display:block;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-black);margin-bottom:6px}textarea.input{min-height:100px;padding:12px 16px;resize:vertical}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23A1A1AA' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.tabs{display:inline-flex;background:var(--color-gray-100);border-radius:var(--radius-md);padding:4px;gap:2px}.tab{padding:6px 16px;border-radius:10px;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-gray-500);background:transparent;border:none;cursor:pointer;transition:all var(--duration-normal) var(--ease-default)}.tab:hover{color:var(--color-black)}.tab.active{background:var(--color-black);color:var(--color-white)}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-8);max-width:560px;width:90%;max-height:80vh;overflow-y:auto;animation:fadeIn var(--duration-slow) var(--ease-out)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.modal-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold)}.modal-close{width:36px;height:36px;border-radius:10px;border:none;background:var(--color-gray-100);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-gray-500);transition:background var(--duration-normal) var(--ease-default)}.modal-close:hover{background:var(--color-gray-200)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-gray-200)}.toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:2000;display:flex;flex-direction:column;gap:var(--space-3)}.toast{padding:16px 20px;border-radius:var(--radius-lg);background:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;min-width:320px;animation:slideIn var(--duration-slow) var(--ease-out)}.toast-success{border-left:4px solid var(--color-primary)}.toast-error{border-left:4px solid var(--color-error)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-message{flex:1;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-black)}.toast-close{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--color-gray-400);display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-close:hover{color:var(--color-black)}.tooltip{background:var(--color-black);color:var(--color-white);padding:8px 12px;border-radius:var(--radius-sm);font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);max-width:240px;box-shadow:0 4px 12px #00000026}.pagination{display:flex;align-items:center;gap:4px}.pagination-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--color-gray-200);background:var(--color-white);font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--duration-normal) var(--ease-default),color var(--duration-normal) var(--ease-default)}.pagination-btn.active{background:var(--color-black);color:var(--color-white);border-color:var(--color-black)}.pagination-btn:hover:not(.active){border-color:var(--color-black);color:var(--color-black)}.toggle{width:44px;height:24px;border-radius:12px;background:var(--color-gray-200);position:relative;cursor:pointer;transition:background var(--duration-normal) var(--ease-default);border:none;flex-shrink:0}.toggle.active{background:var(--color-primary)}.toggle-knob{width:20px;height:20px;border-radius:50%;background:var(--color-white);position:absolute;top:2px;left:2px;transition:transform var(--duration-normal) var(--ease-default);box-shadow:0 1px 3px #0000001a}.toggle.active .toggle-knob{transform:translate(20px)}.skeleton{background:var(--color-gray-200);border-radius:var(--radius-sm);animation:pulse 1.5s ease infinite}.skeleton-text{height:16px;width:60%}.skeleton-title{height:28px;width:40%}.skeleton-card{height:120px;width:100%;border-radius:var(--radius-lg)}.skeleton-row{height:52px;width:100%}.loading-bar{position:fixed;top:0;left:0;right:0;height:3px;background:var(--color-gray-100);z-index:3000}.loading-bar-indicator{height:100%;background:var(--color-primary);animation:indeterminate 1.5s ease infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);gap:var(--space-4)}.empty-state-icon{color:var(--color-gray-300)}.empty-state-text{font-size:var(--font-size-body);color:var(--color-gray-500);text-align:center}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width-collapsed);background:var(--color-black);display:flex;flex-direction:column;align-items:center;padding:var(--space-4) 0;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width var(--duration-slow) var(--ease-default);overflow:hidden}.sidebar:hover{width:var(--sidebar-width-expanded)}.sidebar-logo{width:32px;height:32px;margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-2);width:100%;padding:0 var(--space-3)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-gray-400);text-decoration:none;transition:color var(--duration-normal) var(--ease-default),background var(--duration-normal) var(--ease-default);white-space:nowrap;min-height:40px}.sidebar-link:hover{color:var(--color-white)}.sidebar-link.active{background:#76fb9126;color:var(--color-primary)}.sidebar-link-icon{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-link-label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);opacity:0;transition:opacity var(--duration-normal) var(--ease-default)}.sidebar:hover .sidebar-link-label{opacity:1}.main-wrapper{flex:1;margin-left:var(--sidebar-width-collapsed);display:flex;flex-direction:column;min-height:100vh}.header{height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);position:sticky;top:0;z-index:50}.header-title{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold)}.header-actions{display:flex;align-items:center;gap:var(--space-4)}.header-search{width:320px;height:40px;border:1px solid var(--color-gray-200);border-radius:var(--radius-full);background:var(--color-white);display:flex;align-items:center;padding:0 var(--space-3);gap:var(--space-2);transition:border-color var(--duration-normal) var(--ease-default)}.header-search:focus-within{border-color:var(--color-black)}.header-search input{flex:1;border:none;outline:none;font-size:var(--font-size-small);color:var(--color-black);background:transparent}.header-search input::placeholder{color:var(--color-gray-400)}.header-search-icon{color:var(--color-gray-400);flex-shrink:0}.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-black)}.main-content{flex:1;padding:var(--content-padding);max-width:var(--content-max-width);width:100%;margin:0 auto}.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--space-6)}.kpi-card{grid-column:span 3}.chart-main{grid-column:span 8}.panel-side{grid-column:span 4}.table-full{grid-column:span 12}.toolbar{padding:var(--space-4) var(--space-6);display:flex;align-items:center;justify-content:space-between}.toolbar-actions{display:flex;align-items:center;gap:var(--space-3)}.slide-panel-overlay{position:fixed;inset:0;background:#0006;z-index:500}.slide-panel{position:fixed;top:0;right:0;bottom:0;width:600px;background:var(--color-white);border-radius:var(--radius-xl) 0 0 var(--radius-xl);overflow-y:auto;z-index:501;animation:slideFromRight var(--duration-slow) var(--ease-out)}.text-caption{font-size:var(--font-size-caption);color:var(--color-gray-500)}.text-small{font-size:var(--font-size-small)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-error{color:var(--color-error)}.text-success{color:var(--color-primary-dark)}.flex-center{display:flex;align-items:center;justify-content:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes indeterminate{0%{width:0%;margin-left:0%}50%{width:40%;margin-left:30%}to{width:0%;margin-left:100%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
