@import "https://fonts.googleapis.com/css2?family=Manrope:wght@500;650;750;850&family=Space+Grotesk:wght@500;700&display=swap";:root{--ink:#062337;--muted:#5a7890;--bg:#d7f5ff;--surface:#ffffff8f;--surface-strong:#ffffffbd;--wash:#e9faffb3;--line:#ffffffb8;--line-strong:#309bd35c;--blue:#087fba;--blue-deep:#07527d;--cyan:#20bfe8;--teal:#00a996;--amber:#ffb23f;--shadow:0 24px 70px #0541682e;--inner-glow:inset 0 1px 0 #ffffffdb;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Manrope,Space Grotesk,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 20% 0,#ffffffd1,#0000 30%),linear-gradient(#e8f8ff 0%,#f5fbff 46%,#fbfdff 100%);min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}body:before{content:"";pointer-events:none;opacity:.38;background:linear-gradient(110deg,#0000 0 24%,#ffffff2e 24% 25%,#0000 25% 58%,#087fba0a 58% 59%,#0000 59%);position:fixed;inset:0}button,input,select,textarea{font:inherit}#root{min-height:100vh}.app-shell{grid-template-columns:292px minmax(0,1fr);gap:18px;width:min(1460px,100%);min-height:100vh;margin:0 auto;padding:24px;display:grid}.sidebar,.panel,.metric-chip,.modal-card,.login-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow), var(--inner-glow);-webkit-backdrop-filter:blur(22px)saturate(1.35);backdrop-filter:blur(22px)saturate(1.35)}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border-radius:8px;gap:18px;width:min(440px,100%);padding:26px;display:grid}.login-icon{color:#fff;background:linear-gradient(145deg, var(--cyan), var(--blue-deep));width:52px;height:52px;box-shadow:var(--inner-glow);border-radius:8px;place-items:center;display:grid}.login-card h1{color:var(--ink);letter-spacing:0;margin:0;font-family:Space Grotesk,Manrope,sans-serif;font-size:34px;line-height:1.05}.login-card p{color:var(--muted);margin:8px 0 0}.login-form{gap:12px;display:grid}.login-form label{color:var(--blue-deep);gap:7px;font-size:14px;font-weight:750;display:grid}.login-form input{height:46px;color:var(--ink);box-shadow:var(--inner-glow);background:#ffffffa8;border:1px solid #ffffffa3;border-radius:8px;padding:0 12px}.login-form button{background:linear-gradient(135deg, var(--cyan), var(--blue));color:#fff;cursor:pointer;min-height:46px;box-shadow:var(--inner-glow), 0 12px 28px #045b891f;border:1px solid #20bfe8b3;border-radius:8px;justify-content:center;align-items:center;gap:9px;display:inline-flex}.login-form button:disabled{cursor:wait;opacity:.72}.sidebar{border-radius:8px;align-content:start;gap:18px;height:fit-content;padding:20px;display:grid;position:sticky;top:24px}.brand-block{color:#fff;background:linear-gradient(#042c4514,#043654c7),url(/pool-photo.jpg) 62% 72%/cover;border-radius:8px;align-content:end;gap:8px;min-height:210px;padding:18px;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff59}.brand-block h1,.content-header h2,.panel-title h3,.modal-head h2{color:var(--ink);margin:0;line-height:1.05}.brand-block h1{color:#fff;letter-spacing:0;max-width:220px;font-family:Space Grotesk,Manrope,sans-serif;font-size:34px}.brand-block span{color:#ffffffdb}.brand-block .eyebrow{color:#ffffffc2}.eyebrow{color:var(--blue);letter-spacing:.08em;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:850}.brand-block span,.metric-chip span,.owner-main span,.expense-row span,.timeline span,.search input,.stat-card span,.stat-card small{color:var(--muted)}.menu{gap:8px;display:grid}.menu-item,.primary-action,.file-action,.header-actions button,.expense-form button,.reading-form button,.action-row button,.panel-tools button,.panel-title button,.modal-submit{min-height:44px;color:var(--blue-deep);cursor:pointer;box-shadow:var(--inner-glow), 0 12px 28px #045b891f;background:#ffffff94;border:1px solid #ffffffa8;border-radius:8px;justify-content:center;align-items:center;gap:9px;transition:transform .18s,border-color .18s,background .18s;display:inline-flex}.menu-item:hover,.primary-action:hover,.file-action:hover,.header-actions button:hover,.action-row button:hover,.panel-tools button:hover,.panel-title button:hover,.modal-submit:hover{background:#ffffffc7;border-color:#10a5dd7a;transform:translateY(-1px)}.menu-item{justify-content:flex-start;padding:0 14px}.menu-item.active{color:var(--blue-deep);background:linear-gradient(135deg,#28c3eb42,#ffffffc7);border-color:#38c5ecc2}.menu-item.logout{color:#305b73;margin-top:8px}.primary-action,.file-action,.header-actions button,.action-row button,.panel-tools button,.panel-title button,.modal-submit{padding:0 14px}.content{align-content:start;gap:12px;min-width:0;display:grid}.content-header{justify-content:space-between;align-items:center;gap:16px;padding:10px 8px 0;display:flex}.content-header h2{letter-spacing:0;font-family:Space Grotesk,Manrope,sans-serif;font-size:34px}.summary-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.metric-chip{border-radius:8px;align-items:center;gap:10px;min-height:56px;padding:8px 12px;display:flex}.metric-chip svg{color:var(--cyan);flex:none}.metric-chip span{font-size:12px}.metric-chip strong{color:var(--ink);letter-spacing:0;margin-top:1px;font-family:Space Grotesk,Manrope,sans-serif;font-size:17px;line-height:1.1;display:block}.metric-chip.accent{background:linear-gradient(155deg,#14b8e75c,#fff9);border-color:#48cdf1b8}.workspace{gap:14px;min-width:0;display:grid}.two-column-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.stats-layout{grid-template-columns:repeat(3,minmax(0,1fr))}.energy-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.panel{border-radius:8px;min-width:0;padding:18px}.panel-span-2,.panel-wide{grid-column:1/-1}.panel-title{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.panel-title>svg{color:var(--blue)}.panel-title h3,.modal-head h2{letter-spacing:0;font-family:Space Grotesk,Manrope,sans-serif;font-size:24px}.panel-tools{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:inline-flex}.file-action{min-height:40px;font-weight:750;position:relative;overflow:hidden}.file-action input{opacity:0;pointer-events:none;position:absolute;inset:0}.file-action.loading{opacity:.68;cursor:wait}.owner-list,.income-list,.expense-list,.timeline,.ledger-list,.stats-list{gap:10px;display:grid}.owner-row,.income-row,.expense-row,.timeline-row,.ledger-row,.stat-row,.stat-card{box-shadow:var(--inner-glow);background:#ffffff61;border:1px solid #ffffff8a;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;display:flex}.avatar{color:#fff;background:linear-gradient(145deg, var(--cyan), var(--blue-deep));border-radius:50%;flex:0 0 42px;place-items:center;width:42px;height:42px;font-weight:850;display:grid}.owner-main,.income-row div,.expense-row div,.timeline-row,.ledger-row div{flex:1;min-width:0}.owner-main strong,.income-row strong,.expense-row strong,.timeline-row strong,.ledger-row strong,.stat-row strong,.stat-card strong{color:var(--ink)}.status{border-radius:999px;align-items:center;gap:6px;padding:8px 10px;font-size:14px;font-weight:750;display:inline-flex}.status.paid{color:#005f57;background:#cbfdf2d1}.status.due{color:#7b4b00;background:#ffefcce0}.contribution-table-wrap{width:100%;overflow-x:auto}.contribution-table{border-collapse:separate;border-spacing:0 8px;width:100%;min-width:720px}.contribution-table th,.contribution-table td{text-align:left;padding:0 8px}.contribution-table thead th{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:850}.contribution-table tbody th{width:220px;box-shadow:var(--inner-glow);background:#ffffff61;border:1px solid #ffffff8a;border-right:0;border-radius:8px 0 0 8px;padding:12px 14px}.contribution-table tbody th span,.contribution-table tbody th small{display:block}.contribution-table tbody th span{color:var(--ink);font-family:Space Grotesk,Manrope,sans-serif;font-size:17px;line-height:1.1}.contribution-table tbody th small{color:var(--muted);margin-top:4px;font-size:12px;font-weight:700}.contribution-table tbody td{min-width:150px;box-shadow:var(--inner-glow);background:#ffffff61;border-top:1px solid #ffffff8a;border-bottom:1px solid #ffffff8a;padding:0}.contribution-table tbody td:last-child{border-right:1px solid #ffffff8a;border-radius:0 8px 8px 0}.payment-cell{align-items:center;gap:8px;min-height:64px;padding:12px 14px;font-weight:850;display:flex}.payment-cell.paid{color:#006456}.payment-cell.waiting{color:#9a5a00}.payment-cell.paid svg{color:#00a782}.payment-cell.waiting svg{color:#f59e0b}.action-row{flex-wrap:wrap;gap:10px;display:flex}.search,.modal-form input,.modal-form select,.modal-form textarea{color:var(--ink);box-shadow:var(--inner-glow);background:#ffffffa8;border:1px solid #ffffffa3;border-radius:8px}.search{align-items:center;gap:8px;width:220px;min-height:44px;padding:0 12px;display:flex}.search input{background:0 0;border:0;outline:0;width:100%;min-width:0}.income-row,.expense-row,.ledger-row,.stat-row{justify-content:space-between}.income-main,.expense-main{gap:5px;display:grid}.income-main strong,.income-main span,.expense-main strong,.expense-main span{display:block}.expense-meta{color:var(--muted);font-size:14px;line-height:1.25}.expense-amount{white-space:nowrap;flex:none;margin-left:auto}.icon-action{width:38px;height:38px;color:var(--blue-deep);cursor:pointer;box-shadow:var(--inner-glow);background:#ffffff94;border:1px solid #ffffffa8;border-radius:8px;flex:0 0 38px;place-items:center;display:grid}.icon-action:hover{background:#ffffffc7;border-color:#10a5dd7a;transform:translateY(-1px)}.icon-action.danger{color:#b42318}.deleted-panel{background:#ffffff52}.deleted-list{gap:10px;display:grid}.deleted-row{color:var(--muted);background:#ffffff42;border:1px dashed #305b7347;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.deleted-row div{min-width:0}.deleted-row strong{color:var(--ink);display:block}.deleted-row span{color:var(--muted)}.reading-stats{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;display:grid}.reading-stats div{box-shadow:var(--inner-glow);background:#e8faff85;border:1px solid #ffffff94;border-radius:8px;gap:6px;padding:14px;display:grid}.reading-stats svg{color:var(--cyan)}.reading-stats strong{color:var(--ink);font-family:Space Grotesk,Manrope,sans-serif;font-size:22px}.energy-panel{align-content:start;display:grid}.reading-hero{box-shadow:var(--inner-glow);background:linear-gradient(155deg,#21bce733,#ffffff8f);border:1px solid #ffffff94;border-radius:8px;gap:8px;margin-bottom:14px;padding:18px;display:grid}.reading-hero svg{color:var(--cyan)}.reading-hero strong{color:var(--ink);font-family:Space Grotesk,Manrope,sans-serif;font-size:34px;line-height:1}.reading-hero span{color:var(--muted)}.reading-hero time{color:var(--blue-deep);font-size:14px;font-weight:750}.reading-hero.electric{background:linear-gradient(155deg,#ffb23f33,#ffffff94)}.reading-hero.electric svg{color:var(--amber)}.timeline-row{grid-template-columns:110px minmax(92px,auto) minmax(0,1fr) 38px;align-items:center;display:grid}.timeline time{color:var(--muted);font-size:13px;font-weight:750;display:block}.timeline-row span{min-width:0}.stat-card{align-items:start;gap:6px;display:grid}.chart-list{gap:14px;display:grid}.bar-row{box-shadow:var(--inner-glow);background:#ffffff61;border:1px solid #ffffff8a;border-radius:8px;gap:8px;padding:12px 14px;display:grid}.bar-row>div:first-child{justify-content:space-between;gap:12px;display:flex}.bar-row span,.bar-row small{color:var(--muted)}.bar-row strong{color:var(--ink)}.empty-state{color:var(--muted);background:#ffffff47;border:1px dashed #305b7342;border-radius:8px;margin:0;padding:16px}.bar-track{background:#07527d1a;border-radius:999px;height:10px;overflow:hidden}.bar-track span,.bar-track i{border-radius:inherit;background:linear-gradient(90deg, var(--cyan), var(--blue));height:100%;display:block}.bar-track span.positive{background:linear-gradient(90deg, #48dcbc, var(--teal))}.bar-track span.negative{background:linear-gradient(90deg, #ffcf7c, var(--amber))}.bar-track i.income{background:linear-gradient(90deg, #48dcbc, var(--teal))}.bar-track i.expense{background:linear-gradient(90deg, #ffcf7c, var(--amber))}.year-chart{gap:12px;display:grid}.year-row{box-shadow:var(--inner-glow);background:#ffffff61;border:1px solid #ffffff8a;border-radius:8px;grid-template-columns:92px minmax(0,1fr) 120px;align-items:center;gap:14px;padding:14px;display:grid}.year-row>strong{color:var(--ink);font-family:Space Grotesk,Manrope,sans-serif;font-size:20px}.year-bars{gap:8px;display:grid}.year-bar{grid-template-columns:68px minmax(0,1fr) 112px;align-items:center;gap:10px;display:grid}.year-bar span{color:var(--muted);font-size:13px;font-weight:750}.year-bar strong,.year-balance{color:var(--ink);text-align:right;font-weight:850}.year-balance.positive{color:#006456}.year-balance.negative{color:#9a5a00}.meter-chart{gap:14px;display:grid}.meter-bars{height:250px;box-shadow:var(--inner-glow);background:#ffffff61;border:1px solid #ffffff8a;border-radius:8px;align-items:end;gap:14px;padding:16px;display:flex}.meter-pair{flex:1;justify-content:center;align-items:end;gap:5px;height:100%;display:flex}.meter-pair span{border-radius:999px 999px 4px 4px;width:min(22px,40%);min-height:8px}.meter-pair .water{background:linear-gradient(180deg, var(--cyan), var(--blue))}.meter-pair .power{background:linear-gradient(180deg, #ffcf7c, var(--amber))}.chart-legend{color:var(--muted);flex-wrap:wrap;gap:12px;font-size:14px;display:flex}.chart-legend span{align-items:center;gap:6px;display:inline-flex}.chart-legend i{border-radius:999px;width:10px;height:10px}.water-dot{background:var(--cyan)}.power-dot{background:var(--amber)}.modal-backdrop{z-index:30;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#032a446b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-card{border-radius:8px;width:min(560px,100%);max-height:min(720px,100vh - 40px);padding:22px;animation:.18s ease-out modalIn;position:relative;overflow:auto}.modal-close{width:38px;height:38px;color:var(--blue-deep);cursor:pointer;background:#ffffff9e;border:1px solid #ffffffad;border-radius:8px;place-items:center;display:grid;position:absolute;top:14px;right:14px}.modal-head{margin-bottom:18px;padding-right:46px}.modal-form{gap:12px;display:grid}.modal-form label{color:var(--blue-deep);gap:7px;font-size:14px;font-weight:750;display:grid}.modal-form input,.modal-form select{height:46px;padding:0 12px}.modal-form textarea{resize:vertical;min-height:132px;padding:12px}.confirm-box{box-shadow:var(--inner-glow);background:#ffffff75;border:1px solid #ffffff94;border-radius:8px;gap:6px;padding:14px;display:grid}.confirm-box strong{color:var(--ink)}.confirm-box span{color:var(--muted)}.modal-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.modal-actions button{min-height:44px;color:var(--blue-deep);cursor:pointer;box-shadow:var(--inner-glow);background:#ffffff94;border:1px solid #ffffffa8;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 14px;display:inline-flex}.modal-submit{color:#fff;background:linear-gradient(135deg, var(--cyan), var(--blue));border-color:#20bfe8b3;margin-top:4px}.danger-submit{color:#fff!important;background:linear-gradient(135deg,#f04438,#b42318)!important;border-color:#b423184d!important}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes modalIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.summary-strip,.stats-layout,.two-column-layout,.energy-layout{grid-template-columns:1fr 1fr}.panel-span-2{grid-column:auto}}@media (width<=820px){.app-shell,.stats-layout,.two-column-layout,.energy-layout,.reading-stats{grid-template-columns:1fr}.app-shell{gap:12px;padding:12px}.sidebar{gap:10px;padding:10px;overflow:hidden}.brand-block{background-position:62% 70%;min-height:116px;padding:14px}.brand-block h1{max-width:170px;font-size:28px}.brand-block span{font-size:14px}.menu{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.menu::-webkit-scrollbar{display:none}.summary-strip::-webkit-scrollbar{display:none}.contribution-table-wrap::-webkit-scrollbar{display:none}.menu-item{white-space:nowrap;flex:none;min-height:42px;padding:0 12px}.menu-item.logout{margin-top:0}.content{gap:10px}.summary-strip{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:8px;margin:0 -12px;padding:0 12px 2px;display:flex;overflow-x:auto}.metric-chip{min-width:158px;min-height:52px;padding:8px 10px}.metric-chip strong{font-size:16px}.content-header,.panel-title{gap:12px;padding-inline:0;display:grid}.header-actions{width:100%}.panel-title>svg,.panel-tools>svg{display:none}.content-header h2{font-size:30px}.panel{padding:14px}.panel-title h3,.modal-head h2{font-size:22px}.panel-tools{justify-content:stretch}.panel-tools button,.panel-title button,.file-action,.header-actions button,.search{width:100%}.contribution-table-wrap{scrollbar-width:none;-webkit-overflow-scrolling:touch;margin:0 -6px;padding:0 6px 6px}.contribution-table{min-width:620px}.contribution-table tbody th{z-index:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);width:162px;padding:10px;position:sticky;left:0}.contribution-table tbody th span{font-size:15px}.contribution-table tbody td{min-width:132px}.payment-cell{min-height:56px;padding:10px}.owner-row,.income-row,.expense-row,.timeline-row,.deleted-row,.ledger-row,.stat-row{flex-wrap:wrap;align-items:flex-start}.timeline-row{grid-template-columns:1fr}.income-row,.expense-row,.deleted-row{grid-template-columns:minmax(0,1fr) auto;display:grid}.income-row .icon-action,.expense-row .icon-action{grid-area:1/2/span 2;align-self:center}.expense-amount{grid-column:1;margin-left:0}.reading-hero{padding:14px}.reading-hero strong{font-size:30px}.meter-bars{gap:10px;height:190px;padding:12px}.year-row,.year-bar{grid-template-columns:1fr}.year-bar strong,.year-balance{text-align:left}.modal-backdrop{align-items:end;padding:10px}.modal-card{width:100%;max-height:calc(100vh - 20px);padding:18px}.modal-actions{display:grid}}@media (width<=430px){.login-shell{padding:12px}.login-card{padding:20px}.app-shell{padding:8px}.summary-strip{grid-template-columns:repeat(3,minmax(0,1fr));margin-inline:0;padding-inline:0;display:grid;overflow:visible}.metric-chip{gap:6px;min-width:0}.metric-chip svg{width:14px;height:14px}.metric-chip span{font-size:10px}.metric-chip strong{font-size:14px}.content-header h2{font-size:28px}.panel-title h3,.modal-head h2{font-size:20px}.income-row,.expense-row,.deleted-row{grid-template-columns:1fr}.income-row .icon-action,.expense-row .icon-action{grid-area:auto/1;justify-self:start}}
