:root{--bg-primary: #0a0b0f;--bg-secondary: #12131a;--bg-card: #181a24;--bg-card-hover: #1e2030;--bg-glass: rgba(24, 26, 36, .7);--border: rgba(99, 102, 241, .12);--border-hover: rgba(99, 102, 241, .3);--text-primary: #f0f0f5;--text-secondary: #8b8fa3;--text-muted: #5c5f73;--accent: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99, 102, 241, .2);--cyan: #06b6d4;--cyan-glow: rgba(6, 182, 212, .15);--green: #22c55e;--green-bg: rgba(34, 197, 94, .1);--red: #ef4444;--red-bg: rgba(239, 68, 68, .1);--amber: #f59e0b;--amber-bg: rgba(245, 158, 11, .1);--radius: 16px;--radius-sm: 10px;--radius-xs: 6px;--shadow: 0 4px 24px rgba(0, 0, 0, .3);--transition: .3s cubic-bezier(.4, 0, .2, 1);--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}.view{display:none!important}.view.active{display:flex!important;animation:fadeIn .5s ease}#dashboard-view.active{display:block!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}#upload-view{min-height:100vh;align-items:center;justify-content:center;background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(6,182,212,.06) 0%,transparent 50%),var(--bg-primary)}.upload-container{width:100%;max-width:560px;padding:2rem}.brand{text-align:center;margin-bottom:2.5rem}.brand-icon{width:64px;height:64px;margin:0 auto 1rem;filter:drop-shadow(0 0 20px var(--accent-glow))}.brand-icon.small{width:36px;height:36px;margin:0}.brand h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.accent{-webkit-text-fill-color:var(--cyan)}.tagline{color:var(--text-secondary);font-size:.95rem;margin-top:.3rem;font-weight:400}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg-secondary);position:relative}.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:var(--bg-card);box-shadow:0 0 40px var(--accent-glow)}.drop-zone.has-file{border-color:var(--green);border-style:solid;cursor:default}.drop-icon{width:64px;height:64px;margin:0 auto 1rem;color:var(--text-muted);transition:var(--transition)}.drop-zone:hover .drop-icon{color:var(--accent);transform:translateY(-4px)}.drop-zone h3{font-size:1.1rem;font-weight:600;margin-bottom:.3rem}.drop-zone p{color:var(--text-secondary);font-size:.85rem}.drop-zone-selected{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:var(--bg-card);border-radius:var(--radius-sm)}.file-icon{font-size:2rem}.file-details{flex:1;display:flex;flex-direction:column}.file-name{font-weight:600;font-size:.95rem}.file-size{color:var(--text-secondary);font-size:.8rem}.btn-remove{background:var(--red-bg);color:var(--red);border:none;border-radius:50%;width:32px;height:32px;font-size:.9rem;cursor:pointer;transition:var(--transition)}.btn-remove:hover{background:var(--red);color:#fff}.csv-preview{margin-top:1rem;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);animation:slideUp .3s ease}.csv-preview h4{padding:.8rem 1rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.preview-table-wrap{overflow-x:auto;max-height:200px}.csv-preview table{width:100%;border-collapse:collapse;font-size:.8rem}.csv-preview th{padding:.5rem .8rem;text-align:left;background:var(--bg-secondary);color:var(--text-secondary);font-weight:600;position:sticky;top:0}.csv-preview td{padding:.4rem .8rem;border-top:1px solid var(--border);color:var(--text-primary);white-space:nowrap}.webhook-config{margin-top:1.5rem}.webhook-config label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.04em}.webhook-config input{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:.85rem;transition:var(--transition);outline:none}.webhook-config input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn-primary{width:100%;padding:1rem;margin-top:1.5rem;background:linear-gradient(135deg,var(--accent),var(--cyan));color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 32px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary .btn-loading{display:flex;align-items:center;justify-content:center;gap:.6rem}.btn-ghost{width:100%;padding:.8rem;margin-top:.8rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-ghost:hover{color:var(--accent);border-color:var(--accent)}.btn-outline{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-outline:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow)}.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{margin-top:1rem;padding:.8rem 1rem;background:var(--red-bg);color:var(--red);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);font-size:.85rem}.hidden{display:none!important}#loading-view{min-height:100vh;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,rgba(99,102,241,.1) 0%,transparent 50%),var(--bg-primary)}.loading-container{text-align:center;max-width:400px;padding:2rem}.loading-animation{position:relative;width:120px;height:120px;margin:0 auto 2rem}.loading-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 10px))}}.pulse-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:2px solid var(--accent);border-radius:50%;opacity:0;animation:pulse 2s ease-out infinite}.delay-1{animation-delay:.5s}.delay-2{animation-delay:1s}@keyframes pulse{0%{transform:scale(.5);opacity:.8}to{transform:scale(1.3);opacity:0}}.loading-container h2{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.loading-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.loading-steps{display:flex;flex-direction:column;gap:.8rem;text-align:left}.step{display:flex;align-items:center;gap:.8rem;color:var(--text-muted);font-size:.85rem;transition:var(--transition)}.step.active{color:var(--accent-light)}.step.done{color:var(--green)}.step-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:var(--transition);flex-shrink:0}.step.active .step-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.step.done .step-dot{background:var(--green)}#dashboard-view{padding:1.5rem;max-width:1400px;margin:0 auto}.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.dash-brand{display:flex;align-items:center;gap:.8rem}.dash-brand h1{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.3rem 1.5rem;display:flex;align-items:center;gap:1rem;transition:var(--transition);animation:slideUp .4s ease backwards}.kpi-card:nth-child(1){animation-delay:.05s}.kpi-card:nth-child(2){animation-delay:.1s}.kpi-card:nth-child(3){animation-delay:.15s}.kpi-card:nth-child(4){animation-delay:.2s}.kpi-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}.kpi-total{border-left:3px solid var(--accent)}.kpi-receitas{border-left:3px solid var(--green)}.kpi-despesas{border-left:3px solid var(--red)}.kpi-icon{font-size:2rem}.kpi-info{display:flex;flex-direction:column}.kpi-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:1.4rem;font-weight:800;letter-spacing:-.02em}.kpi-receitas .kpi-value{color:var(--green)}.kpi-despesas .kpi-value{color:var(--red)}.saldo-positivo{border-left:3px solid var(--green)}.saldo-positivo .kpi-value{color:var(--green)}.saldo-negativo{border-left:3px solid var(--red)}.saldo-negativo .kpi-value{color:var(--red)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;animation:slideUp .5s ease backwards;animation-delay:.25s}.chart-card h3{font-size:.95rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.chart-wrap{position:relative;max-height:320px}.insights-card{background:linear-gradient(135deg,#6366f114,#06b6d40d);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;animation:slideUp .5s ease backwards;animation-delay:.3s}.insights-header h3{font-size:1.1rem;font-weight:700;margin-bottom:1rem}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.insight-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.2rem;transition:var(--transition)}.insight-item:hover{border-color:var(--border-hover);transform:translateY(-2px)}.insight-icon{font-size:1.5rem;margin-bottom:.5rem}.insight-title{font-size:.85rem;font-weight:700;margin-bottom:.3rem;color:var(--text-primary)}.insight-text{font-size:.8rem;color:var(--text-secondary);line-height:1.5}.insight-highlight{color:var(--accent-light);font-weight:600}.insight-warning{color:var(--amber);font-weight:600}.insight-danger{color:var(--red);font-weight:600}.insight-success{color:var(--green);font-weight:600}.top-gastos-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;animation:slideUp .5s ease backwards;animation-delay:.35s}.top-gastos-card h3{font-size:1rem;font-weight:700;margin-bottom:1rem}.top-list{display:flex;flex-direction:column;gap:.6rem}.top-item{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}.top-item:hover{background:var(--bg-card-hover)}.top-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent-glow);color:var(--accent-light);border-radius:50%;font-size:.75rem;font-weight:800;flex-shrink:0}.top-item:nth-child(1) .top-rank{background:#ef444426;color:var(--red)}.top-item:nth-child(2) .top-rank{background:#f59e0b26;color:var(--amber)}.top-desc{flex:1}.top-desc-name{font-size:.85rem;font-weight:600}.top-desc-cat{font-size:.7rem;color:var(--text-secondary);margin-top:.1rem}.top-valor{font-size:.95rem;font-weight:700;color:var(--red)}.top-data{font-size:.75rem;color:var(--text-muted)}.transactions-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;animation:slideUp .5s ease backwards;animation-delay:.4s}.transactions-header{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 1.5rem;flex-wrap:wrap;gap:1rem}.transactions-header h3{font-size:1rem;font-weight:700}.transactions-filters{display:flex;gap:.6rem;flex-wrap:wrap}.search-input,.filter-select{padding:.5rem .8rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);font-family:var(--font);font-size:.8rem;outline:none;transition:var(--transition)}.search-input:focus,.filter-select:focus{border-color:var(--accent)}.search-input{min-width:180px}.filter-select{min-width:150px}.table-wrap{overflow-x:auto}.transactions-table{width:100%;border-collapse:collapse}.transactions-table th{padding:.7rem 1rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0}.transactions-table td{padding:.7rem 1rem;font-size:.83rem;border-bottom:1px solid var(--border);transition:var(--transition)}.transactions-table tr:hover td{background:var(--bg-card-hover)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:100px;font-size:.7rem;font-weight:600}.badge-pix{background:#6366f126;color:var(--accent-light)}.badge-debito{background:#f59e0b1f;color:var(--amber)}.badge-credito{background:#06b6d41f;color:var(--cyan)}.badge-outro{background:#8b8fa31f;color:var(--text-secondary)}.badge-cat{display:inline-block;padding:.2rem .6rem;border-radius:100px;font-size:.7rem;font-weight:600;background:#6366f11a;color:var(--accent-light)}.confianca-alta{color:var(--green)}.confianca-media{color:var(--amber)}.confianca-baixa{color:var(--red)}.valor-positivo{color:var(--green);font-weight:700}.valor-negativo{color:var(--red);font-weight:700}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-value{font-size:1.1rem}.transactions-filters,.search-input,.filter-select{width:100%}#dashboard-view{padding:1rem}.dash-header{flex-direction:column;gap:1rem;align-items:flex-start}}@media(max-width:480px){.kpi-grid{grid-template-columns:1fr}.upload-container{padding:1rem}.drop-zone{padding:2rem 1rem}.insights-grid{grid-template-columns:1fr}}
