:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eef3f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:#eef3f7;width:100%;overflow-x:hidden}body{overscroll-behavior-x:none;width:100%;min-width:320px;min-height:100svh;margin:0;overflow-x:hidden}h1,h2,p{margin:0}h1{color:#0f172a;letter-spacing:0;font-size:34px;line-height:1.1}h2{color:#0f172a;letter-spacing:0;font-size:20px;line-height:1.2}#root{min-height:100svh}@media (width<=720px){h1{font-size:28px}h2{font-size:18px}}@media (width<=430px){h1{font-size:25px}}.app-shell{width:min(1440px,100%);margin:0 auto;padding:28px;overflow-x:hidden}.topbar,.month-bar,.section-heading,.entry-actions,.template-actions{align-items:center;display:flex}.topbar{justify-content:space-between;gap:20px;margin-bottom:22px}.header-actions{align-items:center;gap:10px;min-width:0;display:flex}.sync-badge{color:#0f766e;white-space:nowrap;background:#eefbf7;border:1px solid #b7e9dd;border-radius:999px;padding:7px 10px;font-size:13px;font-weight:800}.page-tabs{background:#dfe8ef;border:1px solid #cbd5e1;border-radius:8px;gap:4px;padding:4px;display:inline-flex}.page-tabs button{color:#475569;cursor:pointer;min-height:36px;font:inherit;background:0 0;border:0;border-radius:6px;align-items:center;gap:6px;padding:7px 11px;font-weight:800;display:inline-flex}.page-tabs button.active{color:#0f766e;background:#fff;box-shadow:0 1px 4px #0f172a14}.eyebrow{color:#64748b;letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:700}.summary-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.summary-grid.expense-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card,.calendar-panel,.side-panel,.panel-section,.calculator-panel{background:#fff;border:1px solid #dde4ed;border-radius:8px;box-shadow:0 10px 30px #0f172a0f}.stat-card{align-items:center;gap:12px;min-width:0;min-height:76px;padding:14px;display:flex}.stat-icon{color:#0f766e;background:#d7f5ef;border-radius:8px;flex:none;place-items:center;width:42px;height:42px;display:grid}.stat-icon svg{width:21px;height:21px}.stat-card span{color:#64748b;font-size:13px;display:block}.stat-card strong{color:#0f172a;overflow-wrap:anywhere;margin-top:3px;font-size:22px;line-height:1.15;display:block}.workspace{grid-template-columns:minmax(0,1.45fr) minmax(360px,.75fr);align-items:start;gap:18px;display:grid}.expense-workspace{grid-template-columns:minmax(320px,.7fr) minmax(0,1fr);align-items:start;gap:18px;display:grid}.calendar-panel,.panel-section,.calculator-panel{min-width:0;padding:18px}.side-panel{overflow:hidden}.month-bar{justify-content:space-between;margin-bottom:14px}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.weekday-row{color:#64748b;text-align:center;margin-bottom:8px;font-size:13px;font-weight:700}.calendar-cell{color:#334155;text-align:left;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;justify-content:space-between;min-width:0;min-height:112px;padding:10px;display:flex;position:relative}.calendar-cell.empty{cursor:default;background:0 0;border-color:#0000}.calendar-cell.has-work{background:#eefbf7;border-color:#99e2d0}.calendar-cell.selected{border-color:#0f766e;box-shadow:inset 0 0 0 2px #0f766e}.day-number{align-items:center;gap:5px;font-weight:800;display:inline-flex}.today-dot{background:#f97316;border-radius:999px;width:7px;height:7px}.day-meta{gap:2px;min-width:0;display:grid}.day-meta strong{color:#0f766e;text-overflow:ellipsis;font-size:15px;overflow:hidden}.day-meta small{color:#64748b;font-size:12px}.side-panel .panel-section{box-shadow:none;border:0}.section-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.template-strip,.calendar-quick-add{-webkit-overflow-scrolling:touch;gap:8px;max-width:100%;margin-bottom:14px;padding-bottom:8px;display:flex;overflow-x:auto}.calendar-quick-add{border-bottom:1px solid #e2e8f0;margin:-2px 0 12px}.template-chip,.quick-template-button,.primary-button,.secondary-button,.quick-add-button,.icon-button{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;font-weight:750;display:inline-flex}.template-chip,.quick-template-button{white-space:nowrap;color:#0f766e;background:#eefbf7;border-color:#b7e9dd;gap:6px;padding:8px 10px}.quick-template-button{min-height:38px;font-size:15px}.primary-button{color:#fff;background:#0f766e;gap:8px;padding:11px 12px}.primary-button:disabled{cursor:not-allowed;opacity:.65}.secondary-button{color:#0f172a;background:#fff;border-color:#cbd5e1;gap:8px;padding:10px 12px}.quick-add-button{color:#fff;white-space:nowrap;background:#0f766e;gap:6px;min-height:32px;padding:6px 10px}.icon-button{color:#334155;background:#f8fafc;border-color:#dbe4ee;width:38px;height:38px}.icon-button.compact{width:32px;height:32px}.icon-button.danger{color:#b91c1c}.work-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.work-form label{text-align:left;gap:5px;display:grid}.work-form span{color:#475569;font-size:12px;font-weight:800}.work-form input{box-sizing:border-box;color:#0f172a;width:100%;min-height:42px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:9px 10px}.expense-form{gap:14px;display:grid}.calculator-display{color:#0f172a;background:#eff6f6;border:1px solid #cde7e2;border-radius:8px;justify-content:flex-end;align-items:center;min-height:78px;padding:16px;font-size:38px;font-weight:850;line-height:1;display:flex;overflow:hidden}.calculator-keys{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.calculator-key{color:#0f172a;cursor:pointer;min-height:56px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;font-size:20px;font-weight:850}.calculator-key.muted{color:#475569;background:#f1f5f9}.calculator-key.save-key{color:#fff;background:#0f766e;border-color:#0f766e;grid-column:span 2}.expense-fields{grid-template-columns:minmax(120px,.45fr) minmax(0,1fr);gap:10px;display:grid}.expense-fields label{text-align:left;gap:5px;display:grid}.expense-fields span{color:#475569;font-size:12px;font-weight:800}.expense-fields input,.expense-fields select{box-sizing:border-box;color:#0f172a;width:100%;min-height:42px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:9px 10px}.wide{grid-column:1/-1}.entry-list,.template-list,.breakdown-list,.expense-list{gap:10px;margin-top:16px;display:grid}.entry-item,.template-card,.breakdown-row,.expense-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.entry-item,.template-card,.expense-item{text-align:left;justify-content:space-between;gap:12px;padding:12px;display:flex}.entry-item h3,.template-card h3,.expense-item h3{color:#0f172a;overflow-wrap:anywhere;margin:0 0 5px;font-size:16px}.entry-item p,.template-card p,.expense-item p{color:#64748b;align-items:center;gap:5px;margin:0;font-size:13px;display:inline-flex}.entry-item small{color:#64748b;margin-top:7px;display:block}.entry-actions{flex-direction:column;flex:none;align-items:flex-end;gap:6px}.expense-actions{flex:none;align-items:center;gap:8px;display:flex}.expense-actions strong{color:#be123c}.entry-actions strong{color:#0f766e}.entry-actions span{color:#64748b;font-size:13px}.entry-actions div,.template-actions{gap:6px;display:flex}.template-actions{flex:none;align-items:center}.bottom-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.55fr);gap:18px;margin-top:18px;display:grid}.breakdown-row{justify-content:space-between;gap:12px;padding:12px;display:flex}.breakdown-row span{color:#334155;font-weight:700}.breakdown-row strong{color:#0f766e}.empty-state{color:#64748b;text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;margin:0;padding:14px}.auth-shell{place-items:center;min-height:100svh;display:grid}.auth-panel{background:#fff;border:1px solid #dde4ed;border-radius:8px;width:min(430px,100%);padding:24px;box-shadow:0 10px 30px #0f172a14}.auth-panel h1{margin-bottom:18px}.auth-form{gap:12px;display:grid}.auth-form label{gap:5px;display:grid}.auth-form span{color:#475569;font-size:12px;font-weight:800}.auth-form input{color:#0f172a;min-height:44px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:10px}.auth-message{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:0;padding:10px}.link-button{color:#0f766e;cursor:pointer;font:inherit;background:0 0;border:0;margin-top:14px;padding:0;font-weight:800}button,input{transition:border-color .18s,box-shadow .18s,transform .18s}button:hover{transform:translateY(-1px)}button:focus-visible,input:focus-visible{outline-offset:2px;border-color:#0f766e;outline:3px solid #14b8a63d}@media (width<=1080px){.workspace,.bottom-grid,.expense-workspace{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=720px){.app-shell{width:100%;padding:max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(14px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left))}.topbar{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:14px}.header-actions{flex-direction:column;align-items:stretch;gap:8px;width:100%}.sync-badge{text-overflow:ellipsis;align-self:flex-start;max-width:100%;overflow:hidden}.page-tabs{width:100%}.page-tabs button{flex:1 1 0;min-width:0}.secondary-button{width:100%;min-height:42px}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}.stat-card{gap:8px;min-height:68px;padding:10px}.stat-icon{width:36px;height:36px}.stat-card span{font-size:12px}.stat-card strong{font-size:17px}.calendar-panel,.panel-section,.calculator-panel{padding:10px}.month-bar{margin-bottom:10px}.month-bar h2{text-align:center}.calendar-grid{gap:4px}.calendar-cell{border-radius:6px;min-height:66px;padding:6px 4px}.day-number{font-size:13px}.day-meta strong,.day-meta small{font-size:10px}.work-form,.expense-fields{grid-template-columns:1fr}.entry-item,.template-card,.expense-item{flex-direction:column;align-items:flex-start}.entry-actions{align-items:flex-start;width:100%}.calculator-display{min-height:64px;padding:12px;font-size:30px}.calculator-key{min-height:50px}}@media (width<=430px){.summary-grid,.summary-grid.expense-summary{grid-template-columns:1fr}.calendar-grid{gap:3px}.weekday-row{font-size:11px}.calendar-cell{min-height:58px;padding:5px 3px}.day-meta small{display:none}.quick-template-button{min-height:34px;padding:7px 9px;font-size:14px}.icon-button{width:34px;height:34px}}
