:root{--red: #ef4444;--orange: #f97316;--yellow: #eab308;--blue: #3b82f6;--green: #15803d;--purple: #a855f7;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg: var(--gray-50);--surface: #ffffff;--text: var(--gray-900);--text-muted: var(--gray-500);--border: var(--gray-200);--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--bg)}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}.tabular-nums{font-variant-numeric:tabular-nums}.app{max-width:720px;margin:0 auto;padding:var(--space-4);padding-bottom:64px}.app-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.app-header h1{font-size:22px;margin:0}.app-header .muted{margin:2px 0 0;font-size:12px;color:var(--text-muted)}.muted{color:var(--text-muted)}.error{color:var(--red);font-size:13px;margin:var(--space-2) 0}.center{text-align:center}.spacer{flex:1}.btn-primary,.btn-paid{background:var(--blue);color:#fff;border:0;border-radius:var(--radius-sm);padding:8px 14px;font-weight:600;font-size:13px}.btn-paid{background:var(--green);margin:0 var(--space-3) var(--space-3);align-self:flex-end}.btn-primary:disabled,.btn-paid:disabled{opacity:.6;cursor:not-allowed}.btn-link{background:transparent;border:0;color:var(--blue);font-size:13px;padding:4px 8px}.btn-paid-inline{margin:0}.btn-danger{background:transparent;color:var(--red);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;font-weight:500}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.offline-pill{display:inline-block;background:var(--gray-200);color:var(--gray-700);border-radius:999px;font-size:10px;padding:1px 8px;margin-left:8px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.empty-state{padding:32px 16px}.bill-edit-loading{padding:var(--space-4);color:var(--text-muted);font-size:13px}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);margin-bottom:var(--space-3)}@media (max-width: 600px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}.kpi{background:var(--surface);border-radius:var(--radius);padding:var(--space-3);box-shadow:var(--shadow-sm);border-top:4px solid var(--gray-300);display:flex;flex-direction:column;gap:2px}.kpi-value{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.kpi-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.kpi-red{border-top-color:var(--red)}.kpi-orange{border-top-color:var(--orange)}.kpi-blue{border-top-color:var(--blue)}.kpi-purple{border-top-color:var(--purple)}.summary-bar{background:var(--surface);border-radius:var(--radius);padding:var(--space-3);margin-bottom:var(--space-3);font-size:13px;color:var(--gray-700);box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:6px}.summary-bar strong{color:var(--text)}.filter-chips{display:flex;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-2);margin-bottom:var(--space-3);scrollbar-width:none}.filter-chips::-webkit-scrollbar{display:none}.chip{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:12px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.chip-count{background:var(--gray-100);border-radius:999px;padding:1px 7px;font-size:11px;color:var(--gray-600)}.chip-active{background:var(--gray-900);color:#fff;border-color:var(--gray-900)}.chip-active .chip-count{background:#ffffff26;color:#fff}.bill-list{display:flex;flex-direction:column;gap:var(--space-4)}.bill-group{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.bill-group-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.bill-group-header h2{font-size:13px;margin:0;letter-spacing:.02em;text-transform:uppercase;color:var(--gray-700);flex:1}.group-stripe{width:4px;height:16px;border-radius:2px}.stripe-red{background:var(--red)}.stripe-orange{background:var(--orange)}.stripe-yellow{background:var(--yellow)}.stripe-blue{background:var(--blue)}.stripe-gray{background:var(--gray-400)}.bill-row{display:flex;flex-direction:column;border-left:4px solid var(--gray-200);border-bottom:1px solid var(--border);background:var(--surface)}.bill-row:last-child{border-bottom:0}.bill-row-red{border-left-color:var(--red)}.bill-row-orange{border-left-color:var(--orange)}.bill-row-yellow{border-left-color:var(--yellow)}.bill-row-blue{border-left-color:var(--blue)}.bill-row-gray{border-left-color:var(--gray-300)}.bill-row.expanded{background:var(--gray-50)}.bill-row-main{background:transparent;border:0;text-align:left;padding:var(--space-3) var(--space-4);width:100%;display:flex;flex-direction:column;gap:4px}.bill-row-line1{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-3)}.bill-row-name{font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.star{color:var(--purple);margin-right:4px}.bill-row-amount{font-weight:600;font-size:15px;display:flex;align-items:baseline;gap:var(--space-2)}.paid-suffix{font-size:11px;color:var(--green);font-weight:500}.bill-row-line2{display:flex;flex-wrap:wrap;gap:4px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500;background:var(--gray-100);color:var(--gray-700);white-space:nowrap}.badge-red{background:#fee2e2;color:#b91c1c}.badge-orange{background:#ffedd5;color:#c2410c}.badge-yellow{background:#fef3c7;color:#a16207}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:var(--green)}.badge-purple{background:#f3e8ff;color:#7e22ce}.badge-gray{background:var(--gray-100);color:var(--gray-700)}.bill-edit{padding:var(--space-3) var(--space-4) var(--space-4);background:var(--gray-50);border-top:1px dashed var(--border)}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}@media (max-width: 600px){.grid{grid-template-columns:1fr}}.field{display:flex;flex-direction:column;gap:4px;font-size:13px}.field-full{grid-column:1 / -1}.field-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.field input[type=text],.field input[type=number],.field input[type=date],.field select,.field textarea{border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;background:var(--surface)}.field input[type=checkbox]{width:18px;height:18px}.field textarea{font-family:inherit;resize:vertical}.bill-edit-actions{margin-top:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.signin{max-width:360px;margin:12vh auto;padding:var(--space-6);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);text-align:center}.signin h1{margin-top:0}.dev-signin{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:var(--space-2)}.dev-signin-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin:0}.dev-signin input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}.spinner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);color:var(--text-muted)}.spinner-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--gray-300);border-top-color:var(--blue);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toaster{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--space-2);z-index:50}.toast{background:var(--gray-900);color:#fff;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;box-shadow:var(--shadow-md);cursor:pointer;max-width:90vw}.toast-error{background:var(--red)}.fab{position:fixed;right:max(16px,env(safe-area-inset-right));bottom:max(20px,env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;background:var(--blue);color:#fff;border:0;font-size:28px;font-weight:300;line-height:1;box-shadow:0 4px 12px #3b82f666;cursor:pointer;z-index:30;display:flex;align-items:center;justify-content:center}.fab:hover{background:#2563eb}.fab:active{transform:scale(.95)}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;justify-content:center;align-items:flex-start;padding:24px 16px;z-index:40;overflow-y:auto;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:560px;box-shadow:0 20px 50px #00000040;overflow:hidden;margin:auto 0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:17px}@media (max-width: 600px){.modal-backdrop{padding:0}.modal{border-radius:0;min-height:100vh;max-width:100%}}
