*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg2: #181c27;--bg3: #1e2336;--border: #2a3050;--border2: #3a4570;--text: #e2e8f8;--text2: #8a96b8;--text3: #5a647a;--green: #22c97a;--green-bg: #0d2b1e;--red: #f05b5b;--red-bg: #2b0f0f;--amber: #f5a623;--amber-bg: #2b1e08;--blue: #5b9cf5;--blue-bg: #0d1a2b;--accent: #5b9cf5;--radius: 6px;--font: "IBM Plex Sans", sans-serif;--mono: "IBM Plex Mono", monospace}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font)}input,select,textarea{font-family:var(--font)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.mono{font-family:var(--mono)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-muted{color:var(--text2)}.text-right{text-align:right}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.badge-pago{background:var(--green-bg);color:var(--green)}.badge-pendente{background:var(--amber-bg);color:var(--amber)}.badge-vencido{background:var(--red-bg);color:var(--red)}.badge-cancelado{background:var(--bg3);color:var(--text3)}.badge-receita{background:var(--green-bg);color:var(--green)}.badge-despesa{background:var(--red-bg);color:var(--red)}.input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:8px 12px;font-size:14px;transition:border-color .15s;outline:none}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text3)}.label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;border:none;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.98)}.btn:hover{opacity:.85}.btn-primary{background:var(--accent);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2)}.btn-ghost:hover{border-color:var(--border2);color:var(--text)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bg)}.btn-sm{padding:5px 10px;font-size:12px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);font-weight:500;padding:10px 12px;border-bottom:1px solid var(--border);text-align:left}td{padding:11px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fade-in .15s ease}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:10px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slide-up .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-body{padding:22px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.w-full{width:100%}@media (max-width: 768px){.table-wrap{-webkit-overflow-scrolling:touch}table{min-width:480px}.btn{min-height:44px;padding:10px 14px}.btn-sm{min-height:36px;padding:7px 12px}.input,select{min-height:44px;font-size:16px!important;padding:10px 12px}.card{padding:14px}.modal{max-width:100%;border-radius:10px 10px 0 0}.modal-overlay{align-items:flex-end;padding:0}.grid-2{grid-template-columns:1fr}input,select,textarea{font-size:16px!important}}
