@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-base: #F0F4F8;--bg-card: #FFFFFF;--bg-sidebar: #FFFFFF;--bg-hero: linear-gradient(135deg, #1E40AF 0%, #3B82F6 50%, #60A5FA 100%);--bg-hero-hover: linear-gradient(135deg, #1E3A8A 0%, #2563EB 50%, #3B82F6 100%);--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94A3B8;--text-inverse: #FFFFFF;--accent-blue: #2563EB;--accent-blue-light: #DBEAFE;--accent-blue-dark: #1E40AF;--accent-green: #10B981;--accent-green-light: #D1FAE5;--accent-red: #EF4444;--accent-red-light: #FEE2E2;--accent-orange: #F59E0B;--accent-orange-light: #FEF3C7;--accent-purple: #8B5CF6;--accent-purple-light: #EDE9FE;--accent-pink: #EC4899;--border-color: #E2E8F0;--border-color-hover: #CBD5E1;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.08);--shadow-xl: 0 16px 48px rgba(0,0,0,.1);--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-card-hover: 0 8px 24px rgba(0,0,0,.1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.75rem;--font-size-5xl: 3.5rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--sidebar-width: 260px;--header-height: 64px}:root[data-theme=dark]{--bg-base: #0B0F19;--bg-card: #161D30;--bg-sidebar: #111827;--bg-hero: linear-gradient(135deg, #1E3A8A 0%, #1E40AF 50%, #2563EB 100%);--bg-hero-hover: linear-gradient(135deg, #1E3A8A 0%, #1E40AF 50%, #3B82F6 100%);--text-primary: #F8FAFC;--text-secondary: #94A3B8;--text-tertiary: #64748B;--text-inverse: #FFFFFF;--accent-blue: #3B82F6;--accent-blue-light: rgba(59, 130, 246, .15);--accent-blue-dark: #60A5FA;--accent-green-light: rgba(16, 185, 129, .15);--accent-red-light: rgba(239, 68, 68, .15);--accent-orange-light: rgba(245, 158, 11, .15);--accent-purple-light: rgba(139, 92, 246, .15);--border-color: #1E293B;--border-color-hover: #334155;--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4);--shadow-xl: 0 16px 48px rgba(0,0,0,.5);--shadow-card: 0 1px 3px rgba(0,0,0,.3);--shadow-card-hover: 0 8px 24px rgba(0,0,0,.4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-base);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes progressFill{0%{width:0}}.animate-in{animation:fadeInUp .5s var(--transition-base) backwards}.animate-in-delay-1{animation-delay:.05s}.animate-in-delay-2{animation-delay:.1s}.animate-in-delay-3{animation-delay:.15s}.animate-in-delay-4{animation-delay:.2s}.animate-in-delay-5{animation-delay:.25s}.animate-in-delay-6{animation-delay:.3s}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);grid-template-rows:var(--header-height) 1fr;grid-template-areas:"sidebar header" "sidebar main";min-height:100vh}.sidebar{grid-area:sidebar;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:var(--space-lg);position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;z-index:100;animation:slideInLeft .4s ease-out;overflow-y:auto}.sidebar-brand{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-color)}.sidebar-brand h1{font-size:var(--font-size-lg);font-weight:800;color:var(--accent-blue);letter-spacing:-.02em}.sidebar-brand p{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm);margin-top:var(--space-lg)}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:2px;flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-base);font-weight:500;color:var(--text-secondary);text-decoration:none;position:relative}.sidebar-nav-item:hover{background:var(--accent-blue-light);color:var(--accent-blue);transform:translate(2px)}.sidebar-nav-item.active{background:var(--accent-blue-light);color:var(--accent-blue);font-weight:600}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent-blue);border-radius:var(--radius-full)}.sidebar-nav-item .nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:1rem}.sidebar-nav-item .nav-badge{margin-left:auto;background:var(--accent-blue);color:#fff;font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);min-width:24px;text-align:center}.sidebar-bottom{margin-top:auto;padding-top:var(--space-lg);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--space-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 18px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:var(--accent-blue-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-blue);color:var(--accent-blue);box-shadow:var(--shadow-sm)}.btn-upload{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;padding:12px 20px;border-radius:var(--radius-md);font-size:var(--font-size-base);width:100%;position:relative;overflow:hidden}.btn-upload:hover{background:linear-gradient(135deg,#1e40af,#2563eb);box-shadow:0 4px 16px #2563eb4d;transform:translateY(-2px)}.btn-upload:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-upload:hover:after{left:100%}.header{grid-area:header;background:var(--bg-card);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);position:sticky;top:0;z-index:90;margin-left:var(--sidebar-width)}.header-nav{display:flex;align-items:center;gap:var(--space-xl)}.header-nav a{font-size:var(--font-size-base);font-weight:500;color:var(--text-secondary);text-decoration:none;padding:6px 0;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.header-nav a:hover,.header-nav a.active{color:var(--text-primary);border-bottom-color:var(--accent-blue)}.header-actions{display:flex;align-items:center;gap:var(--space-md)}.header-search{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-base);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 14px;transition:all var(--transition-fast)}.header-search:focus-within{border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a}.header-search input{border:none;background:none;outline:none;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--text-primary);width:180px}.header-search input::placeholder{color:var(--text-tertiary)}.header-search .search-icon{color:var(--text-tertiary);font-size:.9rem}.header-icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);font-size:1rem}.header-icon-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--accent-blue-light)}.header-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.header-avatar:hover{box-shadow:0 0 0 3px #2563eb33;transform:scale(1.05)}.main-content{grid-area:main;margin-left:var(--sidebar-width);padding:var(--space-xl);min-height:calc(100vh - var(--header-height))}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-xl);animation:fadeInUp .5s ease-out}.page-header-left .page-subtitle{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);margin-bottom:var(--space-xs)}.page-header-left .page-title{font-size:var(--font-size-4xl);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1.1}.page-header-left .page-title span{color:var(--accent-blue);font-weight:300}.page-header-right{display:flex;gap:var(--space-sm)}.tab-btn{padding:8px 18px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.tab-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.tab-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.filters-bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);animation:fadeInUp .5s ease-out .05s backwards}.filter-group{position:relative}.filter-select{padding:8px 36px 8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all var(--transition-fast);min-width:160px}.filter-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a}.filter-group:after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:.75rem;pointer-events:none}.filter-chips{display:flex;gap:var(--space-xs);flex-wrap:wrap}.filter-chip{padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-card);font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.filter-chip:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--accent-blue-light)}.filter-chip.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.hero-section{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-lg)}.hero-revenue{background:var(--bg-hero);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-2xl);color:var(--text-inverse);position:relative;overflow:hidden;animation:fadeInUp .5s ease-out .1s backwards;transition:all var(--transition-base)}.hero-revenue:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%}.hero-revenue:after{content:"";position:absolute;bottom:-30%;left:-10%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);border-radius:50%}.hero-revenue:hover{transform:translateY(-2px);box-shadow:0 12px 32px #2563eb4d}.hero-revenue-label{font-size:var(--font-size-sm);font-weight:500;opacity:.85;margin-bottom:var(--space-sm)}.hero-revenue-value{font-size:var(--font-size-5xl);font-weight:800;letter-spacing:-.03em;margin-bottom:var(--space-md);position:relative;z-index:1}.hero-revenue-value .currency{font-size:var(--font-size-2xl);font-weight:400;vertical-align:super;opacity:.8}.hero-revenue-badge{display:inline-flex;align-items:center;gap:var(--space-xs);background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 14px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500}.distribution-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color);animation:fadeInUp .5s ease-out .15s backwards;transition:all var(--transition-base)}.distribution-card:hover{box-shadow:var(--shadow-card-hover)}.distribution-card h3{font-size:var(--font-size-md);font-weight:700;margin-bottom:2px}.distribution-card .dist-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.dist-bar-item{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.dist-bar-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dist-bar-track{flex:1;height:8px;background:var(--bg-base);border-radius:var(--radius-full);overflow:hidden}.dist-bar-fill{height:100%;border-radius:var(--radius-full);transition:width 1s cubic-bezier(.4,0,.2,1);animation:progressFill 1.2s ease-out}.dist-bar-value{font-size:var(--font-size-sm);font-weight:700;color:var(--text-primary);min-width:40px;text-align:right}.activity-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.activity-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color);text-align:center;transition:all var(--transition-base);cursor:default;position:relative;overflow:hidden}.activity-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:transparent}.activity-card-header{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.activity-card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.activity-card-change{font-size:var(--font-size-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.activity-card-change.positive{color:var(--accent-green);background:var(--accent-green-light)}.activity-card-change.negative{color:var(--accent-red);background:var(--accent-red-light)}.activity-card-change.neutral{color:var(--text-tertiary);background:var(--bg-base)}.activity-card-name{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xs);font-weight:500}.activity-card-value{font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.charts-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.chart-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color);transition:all var(--transition-base)}.chart-card:hover{box-shadow:var(--shadow-card-hover)}.chart-card.full-width{grid-column:1 / -1}.chart-card h3{font-size:var(--font-size-md);font-weight:700;margin-bottom:var(--space-xs)}.chart-card .chart-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.chart-container{position:relative;height:280px;width:100%;max-width:100%}.chart-scroll-wrapper{position:relative;height:100%;width:100%}.insights-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.insight-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color);transition:all var(--transition-base)}.insight-card:hover{box-shadow:var(--shadow-card-hover)}.insight-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.insight-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.insight-icon.blue{background:var(--accent-blue-light);color:var(--accent-blue)}.insight-icon.green{background:var(--accent-green-light);color:var(--accent-green)}.insight-icon.orange{background:var(--accent-orange-light);color:var(--accent-orange)}.insight-icon.purple{background:var(--accent-purple-light);color:var(--accent-purple)}.insight-card h4{font-size:var(--font-size-base);font-weight:700}.insight-card .insight-desc{font-size:var(--font-size-xs);color:var(--text-tertiary)}.insight-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.insight-change{font-size:var(--font-size-sm);font-weight:600;margin-left:var(--space-sm)}.insight-change.positive{color:var(--accent-green)}.insight-change.negative{color:var(--accent-red)}.progress-container{margin-top:var(--space-md)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.progress-label{font-size:var(--font-size-xs);font-weight:700;color:var(--accent-blue);background:var(--accent-blue-light);padding:2px 10px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.progress-value{font-size:var(--font-size-base);font-weight:700;color:var(--text-primary)}.progress-track{width:100%;height:10px;background:var(--bg-base);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-blue),#60A5FA);border-radius:var(--radius-full);transition:width 1.5s cubic-bezier(.4,0,.2,1);animation:progressFill 1.5s ease-out}.table-section{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;margin-bottom:var(--space-xl);transition:all var(--transition-base)}.table-section:hover{box-shadow:var(--shadow-card-hover)}.table-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.table-header h3{font-size:var(--font-size-md);font-weight:700}.table-header .table-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary)}.data-table{width:100%;border-collapse:collapse}.data-table thead th{padding:12px var(--space-lg);text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap}.data-table thead th:hover{color:var(--accent-blue);background:var(--accent-blue-light)}.data-table thead th .sort-icon{margin-left:4px;opacity:.4;font-size:.65rem}.data-table thead th.sorted .sort-icon{opacity:1;color:var(--accent-blue)}.data-table tbody tr{transition:all var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-base)}.data-table tbody td{padding:14px var(--space-lg);font-size:var(--font-size-sm);border-bottom:1px solid var(--border-color)}.data-table tbody tr:last-child td{border-bottom:none}.table-activity-name{display:flex;align-items:center;gap:var(--space-sm);font-weight:600}.table-activity-dot{width:10px;height:10px;border-radius:var(--radius-full)}.table-number{font-weight:600;font-variant-numeric:tabular-nums}.table-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.table-badge.top{background:var(--accent-green-light);color:var(--accent-green)}.table-badge.low{background:var(--accent-orange-light);color:var(--accent-orange)}.payment-section{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.payment-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color);transition:all var(--transition-base)}.payment-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.payment-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.payment-card-icon{font-size:1.5rem}.payment-card h4{font-size:var(--font-size-sm);font-weight:600}.payment-card .payment-desc{font-size:var(--font-size-xs);color:var(--text-tertiary)}.payment-card-value{font-size:var(--font-size-2xl);font-weight:800;color:var(--text-primary)}.payment-card-pct{font-size:var(--font-size-sm);font-weight:600;color:var(--text-tertiary);margin-top:var(--space-xs)}.upload-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.upload-overlay.visible{display:flex}.upload-modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-2xl);width:480px;max-width:90vw;text-align:center;animation:scaleIn .3s ease-out;box-shadow:var(--shadow-xl)}.upload-modal h2{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-sm)}.upload-modal p{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xl)}.upload-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2xl);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-lg)}.upload-dropzone:hover,.upload-dropzone.drag-over{border-color:var(--accent-blue);background:var(--accent-blue-light)}.upload-dropzone-icon{font-size:2.5rem;margin-bottom:var(--space-md);color:var(--accent-blue)}.upload-dropzone-text{font-size:var(--font-size-base);font-weight:500;color:var(--text-primary)}.upload-dropzone-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-xs)}.loading-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;align-items:center;justify-content:center}.loading-overlay.visible{display:flex}.loading-spinner{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-2xl) var(--space-2xl);text-align:center;box-shadow:var(--shadow-xl);animation:scaleIn .3s ease-out}.loading-spinner .spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--space-md)}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner p{font-size:var(--font-size-base);font-weight:500;color:var(--text-secondary)}.empty-state{display:none;text-align:center;padding:var(--space-2xl) * 2}.empty-state.visible{display:block}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-lg);opacity:.3}.empty-state h3{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.empty-state p{font-size:var(--font-size-base);color:var(--text-tertiary);margin-bottom:var(--space-xl)}.custom-tooltip{background:var(--text-primary)!important;color:#fff!important;border-radius:var(--radius-sm)!important;padding:var(--space-sm) var(--space-md)!important;font-family:var(--font-family)!important;font-size:var(--font-size-sm)!important;box-shadow:var(--shadow-lg)!important}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-base);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-overlay.active{opacity:1;pointer-events:auto}.login-card{background:var(--bg-card);padding:var(--space-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:400px;border:1px solid var(--border-color);animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-header h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin-bottom:var(--space-xs);letter-spacing:-.02em}.login-header p{color:var(--text-tertiary);font-size:var(--font-size-sm)}.login-form .form-group{margin-bottom:var(--space-lg)}.login-form label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.login-form input{width:100%;padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-base);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-base);transition:all .2s ease}.login-form input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a}.login-btn{width:100%;padding:var(--space-md);font-size:var(--font-size-base);margin-top:var(--space-sm)}.login-error{color:var(--error-color, #ef4444);font-size:var(--font-size-sm);margin-top:var(--space-sm);text-align:center;min-height:20px}@media (max-width: 1200px){.hero-section,.charts-section{grid-template-columns:1fr}.activity-cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width: 1024px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base),visibility var(--transition-base);visibility:hidden}.sidebar.open{transform:translate(0);visibility:visible;box-shadow:4px 0 24px #0f172a26}.app-layout{grid-template-columns:minmax(0,1fr);grid-template-areas:"header" "main"}.header{margin-left:0}.main-content{margin-left:0;padding:var(--space-md)}.insights-section{grid-template-columns:1fr}.payment-section{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}}@media (max-width: 768px){.header{padding:0 var(--space-md)}.header-nav,.header-icon-btn{display:none}.header-search{display:flex!important;flex:1;margin:0 var(--space-sm);padding:6px 12px}.header-search input{width:100%;font-size:var(--font-size-sm)}.search-results{position:fixed;top:var(--header-height);left:12px;right:12px;width:calc(100% - 24px);min-width:0;box-shadow:var(--shadow-xl)}.activity-cards{grid-template-columns:repeat(2,1fr)}.payment-section{grid-template-columns:1fr}.hero-revenue-value{font-size:var(--font-size-3xl)}.page-header-left .page-title{font-size:var(--font-size-2xl)}.data-table{display:block;width:100%;max-width:100%;overflow-x:auto;white-space:nowrap}.filters-bar{flex-wrap:wrap;gap:var(--space-sm)}.chart-card,.activity-card{padding:var(--space-md)}.upload-modal,.compare-modal,.client-modal{padding:var(--space-lg) var(--space-md)}.client-modal-header{gap:var(--space-md);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg)}}@media (max-width: 600px){.client-kpis{grid-template-columns:1fr;gap:var(--space-sm)}}@media (max-width: 480px){.activity-cards{grid-template-columns:1fr}.hero-revenue-value{font-size:var(--font-size-2xl)}.chart-container{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.chart-scroll-wrapper{width:500px}.page-header-right{width:100%;justify-content:space-between}.tab-btn{flex:1;text-align:center;padding:var(--space-sm)}.login-card{width:calc(100% - 32px);padding:var(--space-xl)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.mobile-menu-btn{display:none;width:40px;height:40px;border:none;background:none;cursor:pointer;font-size:1.4rem;color:var(--text-primary)}@media (max-width: 1024px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center}}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:99}.sidebar-overlay.visible{display:block}.retention-section{margin-bottom:var(--space-xl);animation:fadeInUp .5s ease-out .2s backwards}.retention-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.retention-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--space-lg);transition:box-shadow var(--transition-base)}.retention-card:hover{box-shadow:var(--shadow-card-hover)}.retention-card--warn{border-left:4px solid var(--accent-orange)}.retention-card--success{border-left:4px solid var(--accent-green)}.retention-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.retention-card-icon{font-size:1.5rem;flex-shrink:0}.retention-card-header h3{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary);margin-bottom:2px}.retention-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary)}.retention-badge{margin-left:auto;font-size:var(--font-size-lg);font-weight:800;padding:4px 14px;border-radius:var(--radius-full);flex-shrink:0}.retention-badge--red{background:var(--accent-red-light);color:var(--accent-red)}.retention-badge--green{background:var(--accent-green-light);color:var(--accent-green)}.retention-search{margin-bottom:var(--space-md)}.retention-search-input{width:100%;padding:8px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--text-primary);background:var(--bg-base);transition:all var(--transition-fast);outline:none}.retention-search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a;background:var(--bg-card)}.retention-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.retention-list::-webkit-scrollbar{width:4px}.retention-list::-webkit-scrollbar-track{background:transparent}.retention-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.retention-item{display:flex;align-items:center;gap:var(--space-md);padding:10px 12px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.retention-item:hover{background:var(--bg-base)}.retention-item-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:700;color:#fff;flex-shrink:0}.retention-item-avatar--warn{background:linear-gradient(135deg,var(--accent-orange),#F97316)}.retention-item-avatar--success{background:linear-gradient(135deg,var(--accent-green),#059669)}.retention-item-info{flex:1;min-width:0}.retention-item-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.retention-item-meta{font-size:var(--font-size-xs);color:var(--text-tertiary)}.retention-item-amount{font-size:var(--font-size-sm);font-weight:700;color:var(--text-secondary);flex-shrink:0}.retention-empty{text-align:center;padding:var(--space-xl) var(--space-md);color:var(--text-tertiary);font-size:var(--font-size-sm)}.retention-empty-icon{font-size:2rem;margin-bottom:var(--space-sm)}@media (max-width: 900px){.retention-grid{grid-template-columns:1fr}}.compare-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:min(900px,95vw);max-height:90vh;overflow-y:auto;padding:var(--space-xl);box-shadow:var(--shadow-xl);animation:scaleIn .25s ease-out}.compare-modal::-webkit-scrollbar{width:4px}.compare-modal::-webkit-scrollbar-track{background:transparent}.compare-modal::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.compare-modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-xl)}.compare-modal-header h2{font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary);margin-bottom:4px}.compare-modal-header p{font-size:var(--font-size-sm);color:var(--text-tertiary)}.compare-close-btn{background:var(--bg-base);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:32px;height:32px;cursor:pointer;font-size:1rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.compare-close-btn:hover{background:var(--accent-red-light);color:var(--accent-red);border-color:var(--accent-red)}.compare-selectors{display:flex;align-items:flex-end;gap:var(--space-md);margin-bottom:var(--space-xl);padding:var(--space-lg);background:var(--bg-base);border-radius:var(--radius-lg)}.compare-selector-group{flex:1}.compare-label{display:block;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:var(--space-sm)}.compare-select{width:100%}.compare-vs{font-size:var(--font-size-lg);font-weight:900;color:var(--text-tertiary);padding:8px 4px;flex-shrink:0}.compare-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.compare-kpi-card{background:var(--bg-base);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border-color)}.compare-kpi-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:var(--space-md)}.compare-kpi-values{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.compare-kpi-val{flex:1;text-align:center}.compare-kpi-month{font-size:var(--font-size-xs);font-weight:600;margin-bottom:4px;padding:2px 8px;border-radius:var(--radius-full)}.compare-kpi-month--a{background:#dbeafe;color:#1e40af}.compare-kpi-month--b{background:#ede9fe;color:#5b21b6}.compare-kpi-number{font-size:var(--font-size-lg);font-weight:800;color:var(--text-primary)}.compare-kpi-arrow{font-size:1.2rem;flex-shrink:0}.compare-kpi-delta{text-align:center;flex-shrink:0}.compare-kpi-delta-val{font-size:var(--font-size-sm);font-weight:700;padding:3px 10px;border-radius:var(--radius-full)}.compare-kpi-delta-val.positive{background:var(--accent-green-light);color:var(--accent-green)}.compare-kpi-delta-val.negative{background:var(--accent-red-light);color:var(--accent-red)}.compare-kpi-delta-val.neutral{background:var(--bg-base);color:var(--text-tertiary);border:1px solid var(--border-color)}.compare-section-title{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md)}.compare-table-wrap{overflow-x:auto}.compare-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.compare-table thead tr{background:var(--bg-base)}.compare-table th{padding:10px 14px;text-align:left;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);border-bottom:2px solid var(--border-color)}.compare-table th.col-a{color:#1e40af}.compare-table th.col-b{color:#5b21b6}.compare-table td{padding:12px 14px;border-bottom:1px solid var(--border-color);vertical-align:middle}.compare-table tbody tr:hover{background:var(--bg-base)}.compare-table tbody tr:last-child td{border-bottom:none}.compare-table .td-a{color:#1e40af;font-weight:600}.compare-table .td-b{color:#5b21b6;font-weight:600}.compare-delta-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700}.compare-delta-badge.up{background:var(--accent-green-light);color:var(--accent-green)}.compare-delta-badge.down{background:var(--accent-red-light);color:var(--accent-red)}.compare-delta-badge.same{background:var(--bg-base);color:var(--text-tertiary);border:1px solid var(--border-color)}.compare-delta-badge.new{background:var(--accent-blue-light);color:var(--accent-blue)}.compare-empty{text-align:center;padding:var(--space-2xl) var(--space-xl);color:var(--text-tertiary)}.compare-empty p{margin-top:var(--space-md);font-size:var(--font-size-sm)}@media (max-width: 700px){.compare-kpi-row{grid-template-columns:1fr}.compare-selectors{flex-direction:column;align-items:stretch}.compare-vs{text-align:center}}.header-search{position:relative}.search-results{display:none;position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:320px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:200;overflow:hidden;animation:fadeInUp .15s ease-out}.search-results.visible{display:block}.search-result-item{display:flex;align-items:center;gap:var(--space-md);padding:12px 16px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-color)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--accent-blue-light)}.search-result-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:700;color:#fff;flex-shrink:0}.search-result-info{flex:1;min-width:0}.search-result-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:var(--font-size-xs);color:var(--text-tertiary)}.search-result-amount{font-size:var(--font-size-sm);font-weight:700;color:var(--accent-blue);flex-shrink:0}.search-result-empty{padding:20px 16px;text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.client-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:min(700px,95vw);max-height:90vh;overflow-y:auto;padding:var(--space-xl);box-shadow:var(--shadow-xl);animation:scaleIn .25s ease-out}.client-modal::-webkit-scrollbar{width:4px}.client-modal::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.client-modal-header{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border-color)}.client-modal-avatar{width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;color:#fff;flex-shrink:0}.client-modal-info{flex:1}.client-modal-info h2{font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary)}.client-modal-info p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:2px}.client-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.client-kpi{background:var(--bg-base);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);border:1px solid var(--border-color);text-align:center}.client-kpi-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:6px}.client-kpi-value{font-size:var(--font-size-lg);font-weight:800;color:var(--text-primary)}.client-history{display:flex;flex-direction:column;gap:var(--space-sm)}.client-history-month{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden}.client-history-month-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.client-history-month-name{font-size:var(--font-size-sm);font-weight:700;color:var(--text-primary)}.client-history-month-total{font-size:var(--font-size-sm);font-weight:700;color:var(--accent-blue)}.client-history-rows{padding:var(--space-sm) 0}.client-history-row{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:var(--font-size-sm)}.client-history-row:hover{background:#2563eb0a}.client-history-row-act{color:var(--text-secondary);font-weight:500}.client-history-row-amount{color:var(--text-primary);font-weight:700}.client-history-row-date{font-size:var(--font-size-xs);color:var(--text-tertiary)}@media print{body>*:not(#printReport){display:none!important}body{background:#fff!important;color:#000!important;font-family:Inter,sans-serif!important;font-size:12px!important;margin:0!important;padding:0!important}#printReport{display:block!important;position:relative!important;width:100%!important;background:#fff!important;padding:24px!important}.print-header{border-bottom:3px solid #1E40AF;padding-bottom:12px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-end}.print-title{font-size:24px;font-weight:800;color:#1e40af;text-transform:uppercase;letter-spacing:.5px}.print-date{font-size:11px;color:#475569;text-align:right}.print-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.print-kpi{border:1px solid #CBD5E1;border-radius:8px;padding:12px;text-align:center;background:#f8fafc!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-kpi-label{font-size:9px;font-weight:600;color:#64748b;text-transform:uppercase;margin-bottom:4px;letter-spacing:.5px}.print-kpi-value{font-size:18px;font-weight:800;color:#0f172a}.print-section-title{font-size:14px;font-weight:700;color:#1e40af;margin-top:16px;margin-bottom:12px;border-bottom:1px solid #E2E8F0;padding-bottom:4px;page-break-after:avoid}.print-table{width:100%;border-collapse:collapse;margin-bottom:24px}.print-table th{background:#f1f5f9!important;color:#334155;font-size:10px;font-weight:700;text-transform:uppercase;padding:8px 12px;border-bottom:2px solid #CBD5E1;text-align:left;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-table td{padding:8px 12px;border-bottom:1px solid #E2E8F0;font-size:11px;color:#334155}.print-table tr{page-break-inside:avoid}.print-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.print-card{border:1px solid #E2E8F0;border-radius:8px;padding:14px;background:#fff;page-break-inside:avoid}.print-list-item{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed #E2E8F0;font-size:11px}.print-list-item:last-child{border-bottom:none}.print-badge{padding:2px 6px;border-radius:4px;font-size:9px;font-weight:700}.print-badge.green{background:#d1fae5!important;color:#065f46!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-badge.red{background:#fee2e2!important;color:#991b1b!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-kpis,.print-grid,.print-card{page-break-inside:avoid}}
