@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-primary:#efede8;--bg-secondary:#f7f6f3;--bg-card:#fff;--bg-card-hover:#f9f8f6;--bg-glass:#ffffffeb;--bg-input:#f0eee9;--accent-blue:#2563eb;--accent-blue-light:#1d4ed8;--accent-purple:#7c3aed;--accent-green:#059669;--accent-yellow:#d97706;--accent-red:#dc2626;--accent-orange:#ea580c;--accent-pink:#db2777;--accent-cyan:#0891b2;--text-primary:#1a1a1a;--text-secondary:#6b6b6b;--text-muted:#9b9b9b;--text-accent:var(--accent-blue);--border-subtle:#ebebeb;--border-default:#e0ddd8;--border-strong:#ccc8c1;--gradient-brand:linear-gradient(135deg, #d4714e, #c4593c);--gradient-card:linear-gradient(145deg, #fff, #faf9f7);--gradient-success:linear-gradient(135deg, var(--accent-green), #047857);--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 8px #00000014;--shadow-lg:0 4px 16px #0000001a;--shadow-glow-blue:0 2px 12px #2563eb1a;--shadow-glow-purple:0 2px 12px #7c3aed1a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}a,button,[role=button],.sidebar-nav a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;font-size:15px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;line-height:1.3}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}h4{font-size:1.05rem}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);flex-direction:column;flex-shrink:0;width:260px;min-height:100vh;padding:1.5rem 0;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--border-subtle);margin-bottom:1rem;padding:0 1.5rem 1.5rem}.sidebar-brand h1{background:var(--gradient-brand);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800}.sidebar-brand .version{color:var(--text-muted);margin-top:2px;font-size:.7rem}.logout-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;font-size:1rem;display:none}.logout-btn:hover{color:var(--accent-red);background:#dc26261a}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.5rem .75rem;display:flex}.sidebar-nav a{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:10px;padding:.65rem .85rem;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.sidebar-nav a:hover{color:var(--text-primary);background:#3b82f614}.sidebar-nav a.active{color:var(--accent-blue-light);background:#3b82f61f;font-weight:600}.sidebar-nav a .icon{text-align:center;width:24px;font-size:1.15rem}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:1rem 1.5rem}.sidebar-footer button{border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:.55rem;font-size:.8rem}.sidebar-footer button:hover{border-color:var(--accent-red);color:var(--accent-red);background:#ef44440d}.main-content{flex:1;max-width:100%;padding:2rem 2.5rem;overflow-y:auto}.page-header{margin-bottom:1.5rem}.page-header h2{letter-spacing:-.02em;font-size:1.6rem;font-weight:800}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:.9rem}.card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:1.5rem}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header h3{font-size:1rem;font-weight:600}.card-header .badge{color:var(--accent-blue-light);background:#3b82f61f;border-radius:99px;padding:3px 8px;font-size:.7rem;font-weight:600}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:1.25rem;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--gradient-brand);opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.stat-card:hover:before{opacity:1}.stat-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-glow-blue);transform:translateY(-2px)}.stat-card .stat-icon{margin-bottom:.5rem;font-size:1.5rem}.stat-card .stat-value{letter-spacing:-.03em;margin-bottom:4px;font-size:1.8rem;font-weight:800;line-height:1}.stat-card .stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.stat-card.accent-blue .stat-value{color:var(--accent-blue-light)}.stat-card.accent-green .stat-value{color:var(--accent-green)}.stat-card.accent-purple .stat-value{color:var(--accent-purple)}.stat-card.accent-yellow .stat-value{color:var(--accent-yellow)}.stat-card.accent-red .stat-value{color:var(--accent-red)}.stat-card.accent-orange .stat-value{color:var(--accent-orange)}.stat-card.accent-pink .stat-value{color:var(--accent-pink)}.stat-card.accent-cyan .stat-value{color:var(--accent-cyan)}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.85rem}.data-table thead th{background:var(--bg-secondary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default);text-align:left;z-index:1;padding:.75rem 1rem;font-size:.75rem;font-weight:600;position:sticky;top:0}.data-table thead th:first-child{border-radius:var(--radius-md) 0 0 0}.data-table thead th:last-child{border-radius:0 var(--radius-md) 0 0}.data-table tbody td{border-bottom:1px solid var(--border-subtle);color:var(--text-primary);padding:.65rem 1rem}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#3b82f60a}.data-table tbody tr:last-child td{border-bottom:none}.data-table .text-right{text-align:right}.data-table .text-center{text-align:center}.data-table .mono{font-family:JetBrains Mono,monospace;font-size:.8rem}.controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.controls select,.controls input{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-input);color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.85rem}.controls select:focus,.controls input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f626}.controls select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}button.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;padding:.5rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600}button.btn-primary{background:var(--gradient-brand);color:#fff}button.btn-primary:hover{box-shadow:var(--shadow-glow-blue);transform:translateY(-1px)}button.btn-outline{border:1px solid var(--border-default);color:var(--text-secondary);background:0 0}button.btn-outline:hover{border-color:var(--accent-blue);color:var(--accent-blue-light)}.login-container{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:3rem 2.5rem;position:relative;overflow:hidden}.login-box:before{content:"";background:var(--gradient-brand);height:4px;position:absolute;top:0;left:0;right:0}.login-box h1{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:1.5rem}.login-box p{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.login-box input[type=password]{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-input);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;margin-bottom:1rem;padding:.85rem 1rem;font-family:inherit;font-size:1rem}.login-box input[type=password]:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.login-box button{border-radius:var(--radius-md);background:var(--gradient-brand);color:#fff;cursor:pointer;width:100%;transition:all var(--transition-fast);border:none;padding:.85rem;font-family:inherit;font-size:1rem;font-weight:700}.login-box button:hover{box-shadow:var(--shadow-glow-blue);transform:translateY(-1px)}.login-error{color:var(--accent-red);margin-bottom:1rem;font-size:.85rem}.loading{color:var(--text-secondary);justify-content:center;align-items:center;gap:.5rem;padding:3rem;font-size:.9rem;display:flex}.spinner{border:2px solid var(--border-default);border-top-color:var(--accent-blue);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chip{letter-spacing:.02em;border-radius:99px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-block}.chip-blue{color:var(--accent-blue-light);background:#3b82f61f}.chip-green{color:var(--accent-green);background:#10b9811f}.chip-red{color:var(--accent-red);background:#ef44441f}.chip-yellow{color:var(--accent-yellow);background:#f59e0b1f}.chip-purple{color:var(--accent-purple);background:#8b5cf61f}.chart-wrapper{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.5rem}.chart-wrapper h3{margin-bottom:1rem;font-size:1rem;font-weight:600}.grid-2{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.error-msg{border-radius:var(--radius-md);color:var(--accent-red);background:#ef444414;border:1px solid #ef444433;margin-bottom:1rem;padding:1rem 1.25rem;font-size:.9rem}@media (width<=1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.app-layout{flex-direction:column}.sidebar{display:contents}.sidebar-brand{z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);padding:calc(env(safe-area-inset-top,0px) + .6rem) 1rem .6rem;align-items:center;gap:8px;margin-bottom:0;display:flex;position:fixed;top:0;left:0;right:0}.sidebar-brand h1{font-size:1rem}.sidebar-brand .version{margin-top:0;font-size:.65rem}.sidebar-nav{z-index:100;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:.4rem 0 env(safe-area-inset-bottom,.2rem);flex-direction:row;justify-content:space-around;gap:0;position:fixed;bottom:0;left:0;right:0}.sidebar-nav a{white-space:nowrap;text-align:center;border-radius:0;flex-direction:column;flex:1;align-items:center;gap:2px;padding:.35rem 0;font-size:.68rem;display:flex}.sidebar-nav a .icon{width:auto;font-size:1.15rem;display:block}.sidebar-footer{display:none}.logout-btn{justify-content:center;align-items:center;display:flex}.main-content{padding:1rem;padding-top:calc(env(safe-area-inset-top,0px) + 3.5rem);padding-bottom:4.5rem}.grid-2,.grid-3{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.stat-grid{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.region-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;margin-bottom:1.5rem;display:grid}.region-btn{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.55rem .75rem;font-family:inherit;font-size:.82rem;font-weight:600}.region-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue-light);background:#3b82f60d}.region-btn.active{border-color:var(--accent-blue);color:var(--accent-blue-light);background:#3b82f61f}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s forwards fadeIn}.recharts-cartesian-axis-tick-value{fill:var(--text-muted)!important;font-size:.72rem!important}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:.78rem!important}
