:root{--green: #479e61;--green-dark: #3a8350;--dark: #1a1a1a;--bg: #f5f5f3;--surface: #ffffff;--border: #e4e4e0;--muted: #888;--text: #1a1a1a;--danger: #c0392b;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--font: "Aptos", "Calibri", "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}.app{display:flex;flex-direction:column;min-height:100vh}.topbar{background:var(--surface);border-bottom:3px solid var(--green);display:flex;align-items:center;justify-content:space-between;padding:12px 24px;box-shadow:var(--shadow)}.brand{display:flex;align-items:center;gap:12px}.brand-name{font-size:20px;font-weight:700;letter-spacing:4px;color:var(--dark)}.user-box{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}.tabs{display:flex;gap:4px;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border)}.tab{padding:12px 18px;border:none;background:none;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-1px}.tab.active{color:var(--green);border-bottom-color:var(--green)}.tab:disabled{opacity:.4;cursor:not-allowed}.content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.btn{font:inherit;font-weight:600;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);padding:8px 16px;cursor:pointer;transition:background .15s,border-color .15s}.btn:hover{border-color:var(--green)}.btn-primary{background:var(--green);border-color:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}.btn-danger{color:var(--danger);border-color:#e7c3bf}.btn-danger:hover{background:#fbeae8;border-color:var(--danger)}.btn-sm{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.field label{font-size:12px;font-weight:600;color:var(--muted)}input,textarea,select{font:inherit;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--green)}textarea{resize:vertical;min-height:60px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.row{display:flex;gap:12px;align-items:center}.row-wrap{flex-wrap:wrap}.spacer{flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}.card-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin:0 0 14px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-head h1{font-size:22px;margin:0}table.data{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table.data th{background:var(--dark);color:#fff;text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em}table.data th.r,table.data td.r{text-align:right}table.data td{padding:10px 12px;border-bottom:1px solid var(--border)}table.data tr:nth-child(2n) td{background:#fafaf8}table.data tr:hover td{background:#f0f7f2}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:#eef6f0;color:var(--green-dark)}.badge.cat{background:#eef0f5;color:#4a5168}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;z-index:100;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:640px;padding:24px;box-shadow:0 8px 40px #00000040}.modal h2{margin:0 0 16px;font-size:18px}.center-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center}.muted{color:var(--muted)}.error{color:var(--danger);font-size:13px}.empty{text-align:center;color:var(--muted);padding:40px}.toast{position:fixed;bottom:24px;right:24px;background:var(--dark);color:#fff;padding:12px 18px;border-radius:var(--radius);box-shadow:0 4px 20px #0000004d;z-index:200}.totals{margin-left:auto;width:320px;font-size:13px}.totals .line{display:flex;justify-content:space-between;padding:6px 0}.totals .grand{background:var(--green);color:#fff;font-weight:700;padding:8px 12px;border-radius:var(--radius);margin-top:6px}
