:root{--primary: #E4AF00;--primary-soft: #F0D070;--primary-bg: #FFF8E1;--gain: #1A6B3C;--gain-soft: #2E8B57;--gain-bg: #E8F5E9;--cost: #C0392B;--cost-soft: #E57373;--cost-bg: #FDEDEC;--text: #1F1F1F;--text-2: #6B7280;--text-3: #9CA3AF;--label: #374151;--bg: #FAFAF7;--bg-2: #F4F2EC;--card: #FFFFFF;--border: #E5E7EB;--border-strong: #D1D5DB;--shadow-sm: 0 1px 2px rgba(0,0,0,.04), 0 1px 1px rgba(0,0,0,.03);--shadow-md: 0 4px 14px rgba(28,28,28,.06), 0 1px 3px rgba(28,28,28,.04);--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--r-xl: 22px;--gap: 18px;--side: 240px}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}body{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit}.num{font-variant-numeric:tabular-nums}.app{display:grid;grid-template-columns:var(--side) 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--border);padding:22px 14px;display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:10px;padding:4px 10px 18px;border-bottom:1px solid var(--border);margin-bottom:10px}.brand img{width:36px;height:36px;object-fit:contain}.brand-name{font-weight:800;font-size:17px;letter-spacing:.5px}.brand-name span{color:var(--primary)}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--label);font-size:14px;font-weight:500;text-align:left;width:100%;transition:background .12s ease,color .12s ease;text-decoration:none}.nav-item:hover{background:var(--bg-2);color:var(--text)}.nav-item.active{background:var(--primary-bg);color:var(--text);font-weight:700}.nav-item.active .nav-icon{color:var(--primary)}.nav-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-2);flex-shrink:0}.nav-group-label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;padding:14px 12px 6px;font-weight:600}.user-card{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:var(--bg-2)}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:var(--text);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex-shrink:0}.user-name{font-size:13px;font-weight:600}.user-mail{font-size:11px;color:var(--text-2)}.main{padding:20px 28px 60px;min-width:0}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap}.greet h1{margin:0;font-size:22px;font-weight:800}.greet p{margin:2px 0 0;font-size:13px;color:var(--text-2)}.period-bar{display:inline-flex;padding:4px;background:#fff;border:1px solid var(--border);border-radius:12px;gap:2px;box-shadow:var(--shadow-sm)}.period-bar button{padding:7px 14px;border-radius:9px;font-size:13px;font-weight:600;color:var(--text-2);white-space:nowrap}.period-bar button:hover{color:var(--text)}.period-bar button.active{background:var(--text);color:#fff}.head-actions{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:10px;font-size:13px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--text);transition:background .1s ease,border-color .1s ease;cursor:pointer}.btn:hover{background:var(--bg-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:var(--text)}.btn-primary:hover{background:#d4a300;border-color:#d4a300}.btn-ghost{border-color:transparent;background:transparent}.btn-danger{background:var(--cost-bg);border-color:var(--cost);color:var(--cost)}.btn-danger:hover{background:var(--cost);color:#fff}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}.card.tight{padding:16px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}.card-title{font-size:14px;font-weight:700;color:var(--text);margin:0}.card-sub{font-size:12px;color:var(--text-2);margin:2px 0 0}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);margin-bottom:var(--gap)}.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm)}.kpi-head{display:flex;align-items:center;justify-content:space-between}.kpi-label{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.6px}.kpi-icon{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--text-2)}.kpi-icon.gain{background:var(--gain-bg);color:var(--gain)}.kpi-icon.cost{background:var(--cost-bg);color:var(--cost)}.kpi-icon.primary{background:var(--primary-bg);color:#a37d00}.kpi-value{font-size:26px;font-weight:800;letter-spacing:-.5px}.kpi-value.gain{color:var(--gain)}.kpi-value.cost{color:var(--cost)}.kpi-foot{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);flex-wrap:wrap}.delta{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px;font-weight:700;font-size:11.5px}.delta.up{background:var(--gain-bg);color:var(--gain)}.delta.down{background:var(--cost-bg);color:var(--cost)}.delta.flat{background:var(--bg-2);color:var(--text-2)}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:var(--gap);margin-bottom:var(--gap)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-bottom:var(--gap)}.grid-1-1{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-bottom:var(--gap)}.grid-3-2{display:grid;grid-template-columns:3fr 2fr;gap:var(--gap);margin-bottom:var(--gap)}.chart-wrap{width:100%;position:relative}.legend{display:flex;gap:14px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2)}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.chart-tip{position:absolute;pointer-events:none;background:#1f1f1f;color:#fff;font-size:12px;padding:8px 10px;border-radius:8px;white-space:nowrap;transform:translate(-50%,-130%);box-shadow:0 6px 20px #0000002e;opacity:0;transition:opacity .12s ease;z-index:10}.chart-tip.on{opacity:1}.chart-tip:after{content:"";position:absolute;left:50%;bottom:-4px;transform:translate(-50%) rotate(45deg);width:8px;height:8px;background:#1f1f1f}.chart-tip .tip-l{color:#ffffffb3;font-size:11px;display:block;margin-bottom:2px}.chart-tip .tip-v{font-weight:700}.heatmap{display:grid;grid-template-columns:32px repeat(24,1fr);gap:3px}.heatmap-cell{aspect-ratio:1/1;border-radius:4px;background:var(--bg-2);transition:transform 80ms ease;cursor:pointer}.heatmap-cell:hover{transform:scale(1.18);outline:2px solid var(--text);outline-offset:1px;z-index:2;position:relative}.heatmap-row-label{font-size:11px;color:var(--text-2);display:flex;align-items:center;justify-content:flex-end;padding-right:4px}.heatmap-col-labels{display:grid;grid-template-columns:32px repeat(24,1fr);gap:3px;margin-top:6px}.heatmap-col-label{font-size:10px;color:var(--text-3);text-align:center}.donut-row{display:grid;grid-template-columns:160px 1fr;gap:18px;align-items:center}.donut-legend{display:flex;flex-direction:column;gap:10px}.donut-leg-row{display:flex;align-items:center;gap:10px}.donut-leg-row .swatch{width:10px;height:10px;border-radius:3px;flex-shrink:0}.donut-leg-label{font-size:13px;color:var(--text);font-weight:500;flex:1}.donut-leg-value{font-size:13px;font-weight:700}.donut-leg-pct{font-size:11px;color:var(--text-2);margin-left:6px}.insight{padding:14px 16px;border-radius:var(--r-md);background:var(--bg-2);display:flex;gap:12px;align-items:flex-start}.insight+.insight{margin-top:10px}.insight-icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff}.insight-icon.gain{color:var(--gain)}.insight-icon.primary{color:#a37d00;background:var(--primary-bg)}.insight-icon.info{color:#1f1f1f}.insight-icon.cost{color:var(--cost)}.insight-title{font-size:13.5px;font-weight:700;line-height:1.2}.insight-text{font-size:12.5px;color:var(--text-2);margin-top:3px;line-height:1.45}.insight-text strong{color:var(--text);font-weight:700}.goal-ring{position:relative;width:160px;height:160px;margin:8px auto 0}.goal-pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.goal-pct .v{font-size:28px;font-weight:800;letter-spacing:-.5px}.goal-pct .l{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.8px}.goal-meta{text-align:center;margin-top:10px;font-size:13px;color:var(--text-2)}.goal-meta strong{color:var(--text)}.trips{width:100%;border-collapse:collapse}.trips th,.trips td{text-align:left;padding:11px 12px;font-size:13px;border-bottom:1px solid var(--border)}.trips th{font-weight:600;color:var(--text-2);font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;background:var(--bg)}.trips tr:last-child td{border-bottom:none}.trips tr:hover td{background:var(--bg)}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-2);color:var(--text-2)}.pill.pix{background:#e0f2f1;color:#00695c}.pill.dinheiro{background:var(--gain-bg);color:var(--gain)}.pill.cartao{background:#ede7f6;color:#5e35b1}.pill.combust{background:var(--cost-bg);color:var(--cost)}.pill.uber{background:#1f1f1f;color:#fff}.pill.taxi99{background:#ffd000;color:#1f1f1f}.empty-row{color:var(--text-3);font-style:italic;text-align:center;padding:24px 0}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:600;color:var(--label)}.form-group .hint{font-size:12px;color:var(--text-2);margin-top:-2px}.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;outline:none;background:#fff;color:var(--text);transition:border-color .15s ease}.form-input:focus{border-color:var(--primary)}.form-input::placeholder{color:var(--text-3)}.form-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;outline:none;background:#fff;color:var(--text);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-select:focus{border-color:var(--primary)}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.auth-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:36px 32px;box-shadow:var(--shadow-md)}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.auth-logo img{width:40px;height:40px;object-fit:contain}.auth-logo-name{font-weight:800;font-size:20px;letter-spacing:.5px}.auth-logo-name span{color:var(--primary)}.auth-tabs{display:flex;background:var(--bg-2);border-radius:10px;padding:4px;margin-bottom:24px;gap:4px}.auth-tab{flex:1;padding:8px;border-radius:8px;font-size:14px;font-weight:600;text-align:center;color:var(--text-2);transition:all .12s ease}.auth-tab.active{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}.alert{padding:12px 14px;border-radius:10px;font-size:13px;margin-bottom:16px;line-height:1.4}.alert-error{background:var(--cost-bg);color:var(--cost);border:1px solid #f5c6cb}.alert-success{background:var(--gain-bg);color:var(--gain);border:1px solid #c3e6cb}.alert-info{background:var(--primary-bg);color:#7d5f00;border:1px solid #ffeeba}.pagination{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-top:1px solid var(--border)}@media(max-width:1180px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}.grid-2-1,.grid-3-2{grid-template-columns:1fr}}@media(max-width:820px){.app{grid-template-columns:1fr}.sidebar{display:none}.main{padding:16px}.kpi-grid{grid-template-columns:1fr 1fr}.grid-3,.grid-1-1,.donut-row{grid-template-columns:1fr}}@media(max-width:480px){.kpi-grid{grid-template-columns:1fr}.period-bar button{padding:6px 10px;font-size:12px}}
