@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-color: #0f172a;--panel-bg: rgba(30, 41, 59, .7);--border-color: rgba(255, 255, 255, .1);--text-main: #f8fafc;--text-muted: #94a3b8;--accent-1: #3b82f6;--accent-2: #8b5cf6;--accent-3: #10b981;--accent-4: #ef4444;--accent-5: #f59e0b;--shadow: 0 8px 32px 0 rgba(0, 0, 0, .37);--backdrop-blur: blur(12px);--radius: 16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background-color:var(--bg-color);color:var(--text-main);min-height:100vh;margin:0;display:flex;flex-direction:column}#root{min-height:100vh;display:flex;flex-direction:column;padding:2rem;background:radial-gradient(circle at top right,rgba(59,130,246,.12),transparent 40%),radial-gradient(circle at bottom left,rgba(139,92,246,.12),transparent 40%)}.dashboard{max-width:1440px;margin:0 auto;width:100%;animation:fadeIn .8s ease-out}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#06b6d4);-webkit-background-clip:text;background-clip:text;color:transparent;display:flex;align-items:center;gap:.75rem}.header-actions{display:flex;align-items:center;gap:.75rem}.header button{background:var(--panel-bg);border:1px solid var(--border-color);color:var(--text-main);padding:.5rem 1.25rem;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:500;font-size:.875rem;transition:all .25s ease;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur)}.header button:hover{background:#ffffff14;transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.btn-export{background:linear-gradient(135deg,#3b82f6,#8b5cf6)!important;border-color:transparent!important}.btn-export:hover{opacity:.9;box-shadow:0 4px 20px #3b82f666!important}.filters-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;align-items:center;background:#1e293b66;padding:1rem 1.25rem;border-radius:var(--radius);border:1px solid var(--border-color);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur)}.search-box{display:flex;align-items:center;background:#0f172a99;border:1px solid var(--border-color);border-radius:10px;padding:.5rem 1rem;gap:.5rem;flex:1;min-width:250px;color:var(--text-muted);transition:border-color .2s}.search-box:focus-within{border-color:var(--accent-1)}.search-box input{background:transparent;border:none;outline:none;color:var(--text-main);width:100%;font-family:inherit;font-size:.875rem}.search-box input::placeholder{color:var(--text-muted);opacity:.7}.filter-group{display:flex;align-items:center;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:10px;padding:.25rem .75rem;gap:.5rem;color:var(--text-muted);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);transition:border-color .2s}.filter-group:hover{border-color:#fff3}.filter-select{background:transparent;border:none;color:var(--text-main);font-family:inherit;font-size:.875rem;padding:.35rem .25rem;outline:none;cursor:pointer}.filter-select option{background:var(--bg-color);color:var(--text-main)}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}.card{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);box-shadow:var(--shadow);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),border-color .3s;display:flex;flex-direction:column}.card:hover{transform:translateY(-4px);border-color:#fff3}.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-6{grid-column:span 6}.col-span-4{grid-column:span 4}.col-span-3{grid-column:span 3}.stat-card{display:flex;align-items:center;gap:1rem}.stat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:#3b82f626;color:var(--accent-1)}.stat-icon.purple{background:#8b5cf626;color:var(--accent-2)}.stat-icon.green{background:#10b98126;color:var(--accent-3)}.stat-icon.red{background:#ef444426;color:var(--accent-4)}.stat-info h3{font-size:.8rem;color:var(--text-muted);font-weight:500;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.stat-info p{font-size:1.5rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:.25rem}.profit-badge{font-size:.8rem;font-weight:600;color:var(--accent-3);background:#10b98126;padding:.15rem .5rem;border-radius:6px;margin-left:.5rem}.chart-container{flex-grow:1;min-height:300px;width:100%;margin-top:.75rem}.card-title{font-size:1rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem;color:var(--text-main)}.table-container{overflow-x:auto;margin-top:.5rem}table{width:100%;border-collapse:collapse}th,td{padding:.65rem .85rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.06);font-size:.82rem;white-space:nowrap}th{color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:.72rem;position:sticky;top:0;background:#1e293bf2;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur)}tr{transition:background .15s}tr:hover td{background:#3b82f60f}td.row-num{color:var(--text-muted);font-size:.75rem}td.mono{font-family:SF Mono,Fira Code,monospace;font-size:.8rem;color:var(--accent-1)}td.amount{font-weight:600;font-variant-numeric:tabular-nums}td.expense{color:var(--accent-4)}.record-count{font-size:.75rem;font-weight:500;color:var(--text-muted);background:#ffffff0f;padding:.2rem .6rem;border-radius:6px;margin-left:.5rem}.badge{padding:.2rem .6rem;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.badge.received{background:#10b98126;color:var(--accent-3)}.badge.pending{background:#f59e0b26;color:var(--accent-5)}.badge.credit{background:#3b82f626;color:var(--accent-1)}.badge.cancelled{background:#ef444426;color:var(--accent-4)}.pagination{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-color)}.page-btn{display:flex;align-items:center;gap:.35rem;background:#ffffff0f;border:1px solid var(--border-color);color:var(--text-main);padding:.4rem .85rem;border-radius:8px;cursor:pointer;font-size:.82rem;font-weight:500;transition:all .2s;font-family:inherit}.page-btn:hover:not(:disabled){background:#3b82f633;border-color:var(--accent-1)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-info{font-size:.85rem;color:var(--text-muted)}.page-info strong{color:var(--text-main)}.dashboard-footer{text-align:center;padding:2rem 0 1rem;color:var(--text-muted);font-size:.8rem;opacity:.6}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:var(--accent-1)}.spinner{width:44px;height:44px;border:4px solid rgba(59,130,246,.2);border-radius:50%;border-top-color:var(--accent-1);animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1200px){.col-span-8{grid-column:span 12}.col-span-4,.col-span-3{grid-column:span 6}}@media(max-width:768px){.col-span-6,.col-span-4,.col-span-3{grid-column:span 12}#root{padding:1rem}.header{flex-direction:column;align-items:flex-start;gap:1rem}.header h1{font-size:1.75rem}.header-actions{width:100%}.header-actions button{flex:1;justify-content:center}.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:unset}.filter-group,.filter-select{width:100%}.stat-info p{font-size:1.2rem}}.upload-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;animation:fadeIn .6s ease-out}.upload-hero{text-align:center;margin-bottom:3rem}.upload-hero-icon{width:88px;height:88px;border-radius:24px;background:linear-gradient(135deg,#3b82f633,#8b5cf633);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--accent-1);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #3b82f626}50%{box-shadow:0 0 40px #3b82f64d,0 0 60px #8b5cf626}}.upload-hero h1{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#06b6d4);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.75rem}.upload-subtitle{color:var(--text-muted);font-size:1.1rem;max-width:480px;line-height:1.6}.upload-options{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:480px}.upload-dropzone{width:100%;padding:2.5rem 2rem;border:2px dashed rgba(255,255,255,.15);border-radius:20px;background:#1e293b80;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);cursor:pointer;text-align:center;transition:all .3s ease;position:relative}.upload-dropzone:hover{border-color:var(--accent-1);background:#3b82f60f;transform:translateY(-2px);box-shadow:0 8px 32px #3b82f61f}.upload-dropzone.dragging{border-color:var(--accent-2);background:#8b5cf61a;transform:scale(1.02);box-shadow:0 12px 40px #8b5cf633}.upload-dropzone.compact{padding:2rem 1.5rem}.upload-file-input{display:none}.dropzone-icon{width:72px;height:72px;border-radius:18px;background:linear-gradient(135deg,#3b82f626,#8b5cf626);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--accent-1);transition:transform .3s}.upload-dropzone:hover .dropzone-icon{transform:translateY(-4px)}.upload-dropzone.dragging .dropzone-icon{color:var(--accent-2);animation:bounce .5s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.upload-dropzone h3{font-size:1.15rem;font-weight:600;margin-bottom:.35rem;color:var(--text-main)}.upload-dropzone p{color:var(--text-muted);font-size:.9rem}.upload-link{color:var(--accent-1);font-weight:600;text-decoration:underline;text-underline-offset:3px}.upload-formats{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.upload-formats span{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--text-muted);background:#ffffff0d;padding:.25rem .6rem;border-radius:6px}.upload-divider{display:flex;align-items:center;width:100%;gap:1rem}.upload-divider:before,.upload-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.upload-divider span{color:var(--text-muted);font-size:.8rem;font-weight:600;letter-spacing:1px}.upload-default-btn{width:100%;display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#1e293b99;border:1px solid var(--border-color);border-radius:16px;cursor:pointer;color:var(--text-main);text-align:left;transition:all .25s;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);font-family:inherit}.upload-default-btn:hover{background:#3b82f614;border-color:var(--accent-1);transform:translateY(-2px);box-shadow:0 6px 24px #0003}.upload-default-btn strong{display:block;font-size:.95rem;margin-bottom:.2rem}.upload-default-btn span{font-size:.8rem;color:var(--text-muted)}.upload-error{display:flex;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.75rem 1.25rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:var(--accent-4);font-size:.875rem;font-weight:500;animation:fadeIn .3s}.upload-processing{text-align:center;animation:fadeIn .5s ease-out}.upload-processing h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}.upload-processing p{color:var(--text-muted)}.spinner.large{width:56px;height:56px;border-width:5px;margin:0 auto 1.5rem}.data-source-tag{display:flex;align-items:center;gap:.4rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:var(--accent-1);padding:.35rem .75rem;border-radius:8px;font-size:.75rem;font-weight:500;max-width:200px;overflow:hidden;white-space:nowrap}.btn-upload{background:#8b5cf626!important;border-color:#8b5cf64d!important;color:#c4b5fd!important}.btn-upload:hover{background:#8b5cf640!important;border-color:#8b5cf680!important}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .25s}.modal-content{background:#1e293bf2;border:1px solid var(--border-color);border-radius:20px;padding:2rem;max-width:480px;width:100%;position:relative;box-shadow:0 24px 80px #00000080;animation:slideUp .35s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content h2{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.modal-content>p{color:var(--text-muted);font-size:.9rem;margin-bottom:1.25rem}.modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff0f;border:1px solid var(--border-color);color:var(--text-muted);width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-family:inherit}.modal-close:hover{background:#ef444426;color:var(--accent-4);border-color:#ef44444d}@media(max-width:768px){.upload-hero h1{font-size:2rem}.upload-subtitle{font-size:.95rem}.upload-dropzone{padding:1.75rem 1.25rem}.dropzone-icon{width:56px;height:56px;border-radius:14px}.data-source-tag{display:none}.header-actions{flex-wrap:wrap}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}
