:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;background:#eef2f6;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{min-height:100%}body{background:radial-gradient(circle at 0 0,#20745a2e,#0000 34rem),linear-gradient(135deg,#f7fafc 0%,#eef2f6 45%,#e8edf1 100%);min-width:320px;min-height:100%;margin:0}button,input,select{font:inherit}.app-shell{width:min(1120px,100%);margin:0 auto;padding:2rem}.page-header{margin-bottom:1.5rem}.page-header-row{justify-content:space-between;align-items:flex-start;gap:1.5rem;display:flex}.account-actions{color:#4b5563;align-items:center;gap:.75rem;font-size:.875rem;font-weight:700;display:flex}.hero-panel>.account-actions{flex-wrap:wrap;grid-column:1/-1;justify-content:flex-end;justify-self:end}.auth-shell{place-items:center;min-height:100vh;padding:1rem;display:grid}.auth-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:min(440px,100%);padding:1.5rem}.auth-panel h1{font-size:2rem}.auth-form{gap:1rem;margin-top:1rem;display:grid}.eyebrow{color:#276749;letter-spacing:0;text-transform:uppercase;margin:0 0 .75rem;font-size:.875rem;font-weight:700}h1,h2,p{margin-top:0}h1{color:#111827;margin-bottom:.75rem;font-size:clamp(2.25rem,4vw,4rem);line-height:.98}h2{color:#111827;margin-bottom:0;font-size:1.25rem;line-height:1.2}.page-header p:not(.eyebrow){color:#465467;max-width:560px;font-size:1.125rem;line-height:1.6}.hero-panel{background:linear-gradient(135deg,#ffffffeb,#ffffffa8),linear-gradient(135deg,#27674926,#1c4ed81a);border:1px solid #ffffffb8;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(14rem,18rem);align-items:end;gap:1.5rem;padding:clamp(1.5rem,5vw,3rem);display:grid;overflow:hidden;box-shadow:0 24px 70px #0f172a1f}.hero-summary{background:#ffffffc7;border:1px solid #1720331a;border-radius:8px;justify-self:end;gap:.25rem;width:100%;padding:1rem;display:grid;box-shadow:0 12px 30px #0f172a14}.hero-summary-label,.section-kicker{color:#64748b;letter-spacing:0;text-transform:uppercase;margin:0;font-size:.75rem;font-weight:800}.hero-summary strong{color:#111827;font-size:3rem;line-height:1}.hero-summary span:last-child{color:#465467;font-size:.95rem}.content-grid{grid-template-columns:minmax(0,.85fr) minmax(22rem,1.15fr);align-items:stretch;gap:1.5rem;margin-bottom:1.5rem;display:grid}.panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe0;border:1px solid #94a3b847;border-radius:8px;margin-bottom:0;padding:1.25rem;box-shadow:0 16px 45px #0f172a14}.summary-panel,.form-panel,.list-panel{min-width:0}.summary-panel{flex-direction:column;display:flex}.section-heading{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.section-heading span,.pill{color:#276749;background:#effaf3;border:1px solid #27674929;border-radius:999px;align-items:center;min-height:2rem;padding:.25rem .75rem;font-size:.875rem;font-weight:700;display:inline-flex}.pill-success{color:#276749;background:#effaf3;border-color:#27674929}.pill-warning{color:#92400e;background:#fffbeb;border-color:#b4530929}.pill-xs{text-transform:uppercase;min-height:1.25rem;padding:.125rem .5rem;font-size:.65rem}.due-date-cell{align-items:center;gap:.5rem;display:flex}.summary-grid{flex:1;grid-template-rows:repeat(2,minmax(0,1fr));grid-template-columns:1fr;gap:1rem;display:grid}.summary-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-content:center;gap:.5rem;min-height:7rem;padding:1rem;display:grid}.summary-card-primary{background:#f1faf5;border-color:#2767492e}.summary-label{color:#526173;font-size:.875rem;font-weight:700}.summary-value{color:#111827;font-size:clamp(1.5rem,3vw,2rem);line-height:1.2}.expense-form{gap:1rem;display:grid}.form-wide-field{margin-bottom:1rem}.member-form{grid-template-columns:minmax(16rem,1fr) auto;align-items:end;gap:1rem;margin-bottom:1rem;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.form-actions,.table-actions,.table-filters{flex-wrap:wrap;align-items:end;gap:.75rem;display:flex}.table-filters{justify-content:space-between;margin-bottom:1rem}.table-filters label{min-width:14rem}.subtotal-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;gap:.25rem;min-width:12rem;min-height:2.75rem;padding:.5rem .75rem;display:grid}.subtotal-box strong{color:#111827;font-size:1.125rem}.subtotal-error{color:#b91c1c;font-size:.75rem;font-weight:700}label{color:#344256;gap:.375rem;font-size:.875rem;font-weight:700;display:grid}input,select{color:#111827;background:#fff;border:1px solid #cbd5e1;border-radius:6px;width:100%;min-height:2.75rem;padding:.625rem .75rem;transition:border-color .14s,box-shadow .14s,transform .14s}input:focus,select:focus{border-color:#276749;outline:0;box-shadow:0 0 0 4px #27674924}input[aria-invalid=true],select[aria-invalid=true]{border-color:#dc2626}small{color:#b91c1c;font-weight:600}button{color:#fff;cursor:pointer;background:#276749;border:0;border-radius:6px;width:fit-content;min-height:2.75rem;padding:.625rem 1rem;font-weight:700;transition:background .14s,transform .14s,box-shadow .14s}button:hover:not(:disabled){background:#22543d;transform:translateY(-1px);box-shadow:0 10px 20px #27674938}button:disabled{cursor:not-allowed;opacity:.65}.secondary-button{color:#111827;background:#fff;border:1px solid #d1d5db}.danger-button{background:#b91c1c}.danger-button:hover:not(:disabled){background:#991b1b;box-shadow:0 10px 20px #b91c1c33}.table-action{min-height:2.25rem;padding:.45rem .75rem}.muted-text{color:#64748b}.link-button{color:#2563eb;background:0 0;min-height:auto;margin-top:1rem;padding:0}.state-message{color:#526173;margin:0}.state-message.success{color:#047857;font-weight:700}.state-message.error{color:#b91c1c;font-weight:700}.table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.95rem}th{color:#526173;text-transform:uppercase;background:#f8fafc;font-size:.75rem}td{color:#111827}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:#fbfdfb}@media (width<=860px){.hero-panel,.content-grid{grid-template-columns:1fr}.hero-summary{justify-self:stretch}}@media (width<=640px){.app-shell{padding:1rem}.section-heading{flex-direction:column;align-items:flex-start}.page-header-row,.account-actions{flex-direction:column;align-items:stretch}.form-grid{grid-template-columns:1fr}.member-form,.table-filters{grid-template-columns:1fr;display:grid}.table-actions{justify-content:flex-end}button{width:100%}.table-wrap{background:0 0;border:0}table,thead,tbody,tr,th,td{display:block}thead{display:none}tr{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:.75rem;overflow:hidden}td{white-space:normal;justify-content:space-between;align-items:center;gap:1rem;min-height:3rem;display:flex}td:before{color:#526173;content:attr(data-label);text-transform:uppercase;flex:none;font-size:.75rem;font-weight:800}}
