*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f3f4f6;color:#111827}.header{background:#002147;color:#fff;padding:24px 20px}.header .title{font-size:28px;font-weight:700}.header .subtitle{opacity:.85}img.logo{height:32px;width:auto;display:block}.header nav .button.small{background:#ffffff1f;color:#fff;padding:8px 10px;border-radius:8px;font-weight:700}.header nav .button.small:hover{background:#ffffff2e}.container{padding:24px;margin-top:24px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:16px;transition:transform .15s ease,box-shadow .15s ease}.card.clickable{cursor:pointer}.card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0000001f}.card:focus-visible{outline:3px solid #3B82F6;outline-offset:3px}.card h3{margin:0 0 8px;font-size:20px}.card .muted{color:#6b7280}a.card{text-decoration:none;color:inherit;display:block}.badges{display:flex;gap:8px;margin-bottom:8px}.badge{padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;text-transform:capitalize}.badge.admin{background:#8b5cf6}.badge.worker{background:#3b82f6}.badge.active{background:#10b981}.badge.inactive{background:#ef4444}.row{display:flex;gap:8px;align-items:center}.button{background:#3b82f6;color:#fff;border:0;border-radius:8px;padding:10px 14px;font-weight:600;cursor:pointer}.button:disabled{opacity:.6;cursor:not-allowed}.button.secondary{background:#10b981}.button.danger{background:#ef4444}.input{background:#fff;border:1px solid #D1D5DB;border-radius:8px;padding:10px 12px}.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:16px}.toolbar .spacer{flex:1}.toolbar{margin-top:20px}.tabs{display:flex;gap:8px;align-items:center}.tab{background:transparent;color:#111827;border:0;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:700}.tab.active{background:#e6f0ff;color:#0b5fff}.chart{background:#fff;border-radius:12px;padding:12px;box-shadow:0 6px 18px #0000000f}.table th,.table td{padding:8px 10px}.table .right{text-align:right}.totals-row{background:linear-gradient(90deg,#ebf5ff99,#fff)}.totals-row td{font-weight:700}.button+.button{margin-left:6px}.table thead th{position:sticky;top:0;background:#f8fafc;z-index:3}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.finance-card{background:linear-gradient(180deg,#fff,#fbfdff);border-radius:14px;padding:18px;box-shadow:0 12px 30px #0a143212;display:flex;flex-direction:column;gap:12px;min-height:160px;transition:transform .18s ease,box-shadow .18s ease;border:1px solid rgba(15,23,42,.04)}.finance-card:hover{transform:translateY(-6px);box-shadow:0 26px 60px #0a14321f}.finance-card.positive{border-left:6px solid #10B981;background:linear-gradient(180deg,#f7fffb,#fff)}.finance-card.neutral{border-left:6px solid #94A3B8;background:linear-gradient(180deg,#fff,#fbfdff)}.finance-card.violet{border-left:6px solid #8B5CF6;background:linear-gradient(180deg,#fbf7ff,#fff)}.finance-card.danger{border-left:6px solid #EF4444;background:linear-gradient(180deg,#fff7f7,#fff)}.status-badge{display:inline-block;padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px;color:#fff}.finance-card.positive .status-badge{background:#059669}.finance-card.neutral .status-badge{background:#64748b}.finance-card.violet .status-badge{background:#6d28d9}.finance-card.danger .status-badge{background:#dc2626}.finance-card .card-head{display:flex;justify-content:space-between;align-items:center}.finance-card .card-body{padding-top:8px;border-top:1px solid #eef2f7}@media (max-width: 640px){.cards-grid{grid-template-columns:1fr}}.footer{padding:16px;text-align:center;color:#6b7280}.shell{display:flex;flex-direction:column;min-height:100vh}main.content{flex:1}@media (max-width: 1024px){.container{padding:16px;margin-top:20px}.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}}@media (max-width: 640px){.container{padding:12px;margin-top:16px}.grid{grid-template-columns:1fr;gap:12px}}.modalBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modalCard{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:24px;width:420px;max-width:calc(100% - 32px);text-align:center}.modalCard .lock{font-size:32px}.modalCard .title{font-weight:700;font-size:20px;margin-top:8px}.modalCard .muted{color:#6b7280;margin-top:4px}.modalActions{display:flex;justify-content:center;margin-top:16px}.loginPage{display:flex;flex-direction:column;min-height:100vh}.loginLayout{display:flex;flex:1}.loginLeft{flex:1;background:#f3f4f6;color:#111827;display:flex;align-items:center;justify-content:center;padding:48px}.brandWrap{display:flex;align-items:center;gap:16px}.brandText{display:grid;gap:4px}.appName{font-size:28px;font-weight:700;letter-spacing:.5px}.appTag{opacity:.85}.loginRight{flex:1;background:#002147;color:#fff;display:flex;align-items:center;justify-content:center;padding:48px}.loginLeft .logo{height:96px;width:auto}.authCard{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0000001f;padding:28px;width:420px;max-width:100%}.authTitle{font-size:22px;font-weight:700}.authSubtitle{color:#6b7280;margin-top:4px}.authError{color:#ef4444;margin-top:8px}.formGrid{display:grid;gap:12px;margin-top:16px}.formLabel{font-weight:600}@media (max-width: 900px){.loginLayout{flex-direction:column}.loginLeft,.loginRight{padding:24px}}.table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 1px #0000000a;border-radius:8px}.table th,.table td{padding:10px 12px;border-bottom:1px solid #eef2f7;text-align:left;vertical-align:middle;font-size:.95rem;color:#111827}.table thead th{position:sticky;top:0;background:#f8fafc;z-index:2;font-weight:700}.table tbody tr:nth-child(2n){background:#fbfbfd}.table tbody tr:hover{background:#f1f5f9}.table td .button{padding:6px 10px;font-size:.85rem}.view-toggle .button.active{background:#0b5fff;color:#fff;border-color:#0b5fffe6}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:6px}.avatar{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,#eef2ff,#e0f2fe);display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#0b5fff}.text-truncate{max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.button.small,.button.small:visited{padding:6px 8px;font-size:.85rem;border-radius:6px}.badge.small{padding:4px 8px;font-size:.8rem;border-radius:999px}.modalCard svg{display:block;margin:8px 0 4px}.modalCard text{font-family:inherit}
