:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#eef4ff 0%,#f8faff 40%,#f6f8fc 100%);font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.35}*{box-sizing:border-box}body{background:0 0;min-height:100svh;margin:0}#root{width:100%}.app-shell{gap:.65rem;max-width:960px;margin:0 auto;padding:.7rem;display:grid}h1,h2,h3,p{margin:0}h1{letter-spacing:-.01em;margin-bottom:.15rem;font-size:1.08rem}h2{font-size:.9rem}h3{font-size:.82rem}.app-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.header-actions{align-items:center;gap:.4rem;display:flex}.muted{color:#64748b;font-size:.72rem}.forecast-note{margin-top:.1rem;font-size:.7rem}.card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border:1px solid #dbe6f7;border-radius:14px;padding:.62rem;box-shadow:0 10px 24px #0f172a0f}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.25rem;display:flex}.summary-grid{flex-wrap:wrap;align-items:stretch;gap:.35rem;display:flex}.summary-card{color:#f8fafc;background:#111827;border-radius:8px;flex:108px;min-width:108px;max-width:150px;padding:.45rem}.summary-card p{font-size:.86rem;font-weight:700}.summary-card h3{font-size:.68rem;line-height:1.2}.bill-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;margin-top:.4rem;display:grid}.bill-form .full-span{grid-column:1/-1}.bill-form label{color:#334155;gap:.25rem;font-size:.75rem;display:grid}.bill-form input,.bill-form select{background:#fff;border:1px solid #c8d8f1;border-radius:10px;padding:.42rem .5rem;font-size:.78rem;transition:border-color .2s,box-shadow .2s}.bill-form input:focus,.bill-form select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f626}.actions-row{flex-direction:column;align-items:stretch;gap:.35rem;display:flex}.button{cursor:pointer;border:none;border-radius:10px;padding:.4rem .58rem;font-size:.74rem;font-weight:600;transition:transform .15s,box-shadow .2s,opacity .2s}.button:hover{transform:translateY(-1px)}.button.primary{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#3b82f6 100%);box-shadow:0 6px 14px #2563eb3d}.button.secondary{color:#1e293b;background:#f1f5f9;border:1px solid #d9e2ef}.export-button{white-space:nowrap}.hidden-input{display:none}.button.danger{color:#991b1b;background:#fff1f2;border:1px solid #fecdd3}.error-text{color:#b91c1c;grid-column:1/-1;font-size:.72rem}.upcoming-list{gap:.35rem;margin:.45rem 0 0;padding:0;list-style:none;display:grid}.upcoming-item{border:1px solid #e2e8f0;border-radius:8px;gap:.3rem;padding:.45rem;display:grid}.upcoming-meta{justify-content:space-between;align-items:center;gap:.35rem;display:flex}.chip{letter-spacing:.01em;border-radius:999px;padding:.14rem .45rem;font-size:.65rem;font-weight:700}.chip.ok{color:#166534;background:#dcfce7}.chip.warn{color:#9a6700;background:#fff7d6}.chip.overdue{color:#991b1b;background:#fee2e2}.empty-state{color:#64748b;margin-top:.45rem;font-size:.72rem}.bill-cards{gap:.55rem;margin:.45rem 0 0;padding:0;list-style:none;display:grid}.category-section+.category-section{margin-top:.9rem}.category-title{color:#64748b;letter-spacing:.08em;text-transform:lowercase;justify-content:center;align-items:center;gap:.35rem;margin:.2rem 0 .15rem;font-size:.66rem;display:flex}.category-title:before,.category-title:after{content:"—";color:#94a3b8;font-weight:600}.top-category-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem;margin-bottom:.55rem;display:grid}.top-summary-card{background:linear-gradient(#f7fbff 0%,#edf5ff 100%);border:1px solid #d8e7ff;border-radius:12px;padding:.48rem;box-shadow:0 4px 10px #2563eb14}.top-summary-card h4{color:#1d4ed8;align-items:center;gap:.28rem;margin:0 0 .18rem;font-size:.68rem;display:flex}.summary-icon{background:#3b82f624;border-radius:999px;justify-content:center;align-items:center;width:1rem;height:1rem;font-size:.66rem;display:inline-flex}.top-summary-card p{color:#475569;font-size:.68rem}.bill-card{background:linear-gradient(#fff 0%,#f4f9ff 100%);border:1px solid #dbe7ff;border-radius:14px;gap:.5rem;padding:.62rem;transition:box-shadow .2s,transform .2s;display:grid;box-shadow:0 6px 16px #0f172a12}.bill-card:hover{transform:translateY(-1px);box-shadow:0 12px 24px #2563eb29}.bill-card-head{justify-content:space-between;align-items:center;gap:.4rem;display:flex}.bill-title-wrap{align-items:center;gap:.45rem;min-width:0;display:flex}.bill-card-head h3{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;overflow:hidden}.bill-card-head .kind-inline{color:#94a3b8;font-size:.68rem;font-weight:500}.brand-avatar{background:#e2e8f0;border-radius:999px;flex:0 0 1.45rem;justify-content:center;align-items:center;width:1.45rem;height:1.45rem;display:inline-flex;overflow:hidden}.brand-logo{object-fit:cover;width:100%;height:100%}.brand-fallback{color:#1e3a8a;background:#dbeafe;justify-content:center;align-items:center;width:100%;height:100%;font-size:.56rem;font-weight:700;display:inline-flex}.bill-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.28rem .45rem;margin:0;display:grid}.bill-grid dt{color:#64748b;font-size:.62rem}.bill-grid dd{margin:.03rem 0 0;font-size:.71rem;font-weight:600}.inline-actions{flex-wrap:wrap;gap:.28rem;display:flex}.view-switch{grid-template-columns:1fr 1fr;gap:.3rem;display:grid}.quick-glance-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem;display:grid}.quick-glance-grid strong{color:#0f172a;font-size:.8rem;display:block}.quick-label{color:#64748b;font-size:.62rem;display:block}.quick-metric{padding:0}.pagination-row{justify-content:space-between;align-items:center;gap:.4rem;margin-top:.45rem;display:flex}.plus-fab{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#3b82f6 100%);border:none;border-radius:50%;width:44px;height:44px;font-size:1.45rem;line-height:1;position:fixed;bottom:.7rem;right:.7rem;box-shadow:0 12px 24px #2563eb52}.modal-backdrop{z-index:50;background:#0f172a73;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #dbe6f7;border-radius:14px;gap:.55rem;width:min(460px,100%);padding:.85rem;display:grid;box-shadow:0 20px 45px #0f172a40}.modal-mode-list{color:#334155;gap:.28rem;margin:0;padding-left:1rem;font-size:.75rem;display:grid}.modal-actions{justify-content:flex-end;gap:.4rem;display:flex}@media (width>=768px){h1{font-size:1.2rem}.actions-row{flex-direction:row;grid-column:1/-1;align-items:center}.upcoming-item{justify-content:space-between;align-items:center;display:flex}.view-switch{width:210px}.quick-glance-grid strong{font-size:.78rem}.plus-fab{bottom:1rem;right:1rem}}
