:root{font-family:Segoe UI,Trebuchet MS,sans-serif;color:#10243a;background:radial-gradient(circle at 15% 20%,#dff2ff 0,#f4f8fc 40%,#f6f6f1)}*{box-sizing:border-box}body{margin:0}.global-logo-bar{width:100vw;margin-left:calc(50% - 50vw);background:#fff}.global-logo-inner{max-width:1200px;margin:0 auto;padding:8px 18px}.global-logo{width:110px;height:auto;display:block;margin-left:-4px}.login-page{min-height:100vh;display:grid;place-items:center;padding:18px}.login-card{width:min(420px,100%);background:#fff;border:1px solid #d8e6f5;border-radius:16px;padding:20px;box-shadow:0 8px 20px #10355a14}.login-card h1{margin:0}.login-card p{margin:8px 0 14px;color:#4f6780}.login-logo{display:block;width:min(320px,100%);margin:0 auto 10px}.login-form{display:grid;gap:10px}.login-form label{display:grid;gap:4px;color:#2d4b67;font-size:.9rem}.login-form input{border:1px solid #bfd4e8;border-radius:10px;padding:10px}.login-form button{border:0;border-radius:10px;padding:10px 12px;font-weight:700;background:linear-gradient(90deg,#0f6ab8,#2296bc);color:#fff;cursor:pointer}.auth-error{color:#b33b2e}.login-site{display:block;margin-top:6px;text-align:center;color:#5a7189;font-size:.78rem}.app{max-width:1200px;margin:0 auto;padding:18px;overflow-x:clip}.hero h1{margin:0;font-size:clamp(1.35rem,2.7vw,1.95rem)}.hero p{margin-top:8px;color:#3f5973}.sync-row{margin-top:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sync-row small{color:#3f5973}.sync-button{border:0;border-radius:10px;padding:8px 12px;background:linear-gradient(90deg,#0f6ab8,#2296bc);color:#fff;font-weight:700;cursor:pointer}.sync-button:disabled{opacity:.7;cursor:wait}.summary-grid{margin-top:24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.summary-card{background:#fff;border:1px solid #d8e6f5;border-radius:16px;padding:16px}.summary-card h3{margin:0;color:#53708b;font-size:.92rem;text-transform:uppercase}.summary-value{margin:10px 0 4px;font-size:1.6rem;font-weight:800;color:#10243a}.summary-card span{color:#53708b;font-size:.88rem}.summary-net-line-wrap{margin-top:10px;overflow:hidden}.summary-net-line{width:100%;height:auto;aspect-ratio:8 / 3;display:block;overflow:hidden}.summary-net-value-label{font-size:10px;fill:#355b80;font-weight:700}.summary-net-month-label{font-size:10.5px;fill:#5a7189}.panel-grid{margin-top:24px;display:grid;grid-template-columns:1fr;gap:16px}.app-footer{margin-top:18px;text-align:center;color:#5a7189;font-size:.8rem}.panel-subtitle{color:#4f6780;margin-top:6px;margin-bottom:12px}.source-list{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:8px}.source-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #d3e3f4;border-radius:18px;overflow:hidden;box-shadow:0 6px 14px #10355a0f}.source-card.closed{min-height:0}.source-card.open{grid-column:1 / -1}.source-card.closed .source-header{height:auto;display:grid;grid-template-columns:minmax(0,1fr) 170px;grid-template-rows:auto auto;grid-template-areas:"head trend" "nums trend";align-content:stretch;gap:6px 10px;align-items:stretch;justify-items:stretch}.source-card.closed .source-numbers{grid-area:nums;width:100%;display:grid;grid-template-columns:1fr;gap:4px}.source-card.closed .metric-chip{width:100%;text-align:left;min-width:0;padding:5px 6px}.source-card.closed .source-header>div:first-child,.source-card.closed .mini-trend{width:100%}.source-card.closed .source-header>div:first-child{grid-area:head}.mini-trend{grid-area:trend;width:100%;border:1px solid #d8e6f4;border-radius:10px;background:#f4f8fd;padding:5px 7px;align-self:start;height:100%;margin-top:0;display:flex;flex-direction:column;justify-content:flex-start}.mini-trend-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:#4f6780;margin-bottom:4px}.mini-trend-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:auto}.mini-month{display:grid;justify-items:center;gap:2px}.mini-month small{font-size:.68rem;color:#5a7189}.mini-month-bars{width:100%;min-height:44px;display:grid;grid-template-columns:1fr 1fr;gap:3px;align-items:end}.mini-bar{display:block;border-radius:4px 4px 0 0;min-height:4px}.income-bar{background:linear-gradient(180deg,#39bb73,#067d3f)}.expense-bar{background:linear-gradient(180deg,#d66a5d,#b33b2e)}.source-header{width:100%;border:0;background:#fff;text-align:left;padding:12px;cursor:pointer;display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}.source-header h4{margin:0;font-size:1.05rem}.source-header p{margin:2px 0 0;color:#4f6780;font-size:.82rem}.source-numbers{display:flex;gap:8px;min-width:0;flex-wrap:wrap;justify-content:flex-end}.metric-chip{display:grid;gap:1px;min-width:0;padding:5px 8px;border-radius:10px;background:#f1f6fc;border:1px solid #d8e6f4;text-align:right}.metric-chip small{font-size:.68rem;text-transform:uppercase;letter-spacing:.03em}.metric-chip strong{font-size:.86rem}.income{color:#067d3f}.expense{color:#b33b2e}.net.positive{color:#123f72}.net.negative{color:#b33b2e}.source-detail{border-top:1px solid #d8e6f5;padding:18px 18px 20px;display:grid;grid-template-columns:1fr;gap:18px;background:#f9fbff;min-width:0}.source-detail>div{min-width:0}.detail-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.category-split-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.category-column{background:#fff;border:1px solid #d8e6f5;border-radius:12px;padding:10px 12px}.category-column h6{margin:0 0 8px;font-size:.85rem;text-transform:uppercase;color:#53708b}.source-detail h5{margin:0 0 8px}.section-subtitle{margin-top:18px;margin-bottom:10px;font-size:.98rem;color:#244766}.personal-customizer .section-subtitle{display:block;padding-top:12px;margin-top:14px}.source-detail ul{margin:0;padding-left:18px}.entries{list-style:none;padding-left:0}.entries li{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid #e3edf8}.entries li:last-child{border-bottom:0}.entries li div{display:grid;gap:2px}.entry-meta{color:#5a7189;font-size:.75rem}.personal-customizer{grid-column:1 / -1;background:#fff;border:1px solid #d8e6f5;border-radius:12px;padding:16px;margin-top:4px;min-width:0}.collapsible-block{border:1px solid #d8e6f5;border-radius:10px;background:#f8fbff}.collapsible-block+.collapsible-block{margin-top:12px}.collapsible-title{cursor:pointer;padding:10px 12px;font-weight:700;color:#244766;list-style:none}.collapsible-title::-webkit-details-marker{display:none}.collapsible-title:after{content:"+";float:right;color:#416280}.collapsible-block[open] .collapsible-title:after{content:"-"}.collapsible-content{padding:2px 12px 12px}.inline-action{border:1px solid #a9c5df;border-radius:8px;background:#eef5fc;color:#1f4f78;font-weight:700;padding:7px 10px;cursor:pointer}.inline-danger{border:1px solid #e2b6b1;border-radius:8px;background:#fff3f1;color:#9f2f22;font-weight:700;padding:7px 10px;cursor:pointer}.create-category-form{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,.9fr) auto;gap:8px;align-items:end;margin-top:10px}.create-item-form{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;align-items:end;margin-top:8px;min-width:0}.create-item-form label{display:grid;gap:4px;font-size:.85rem;color:#2d4b67;min-width:0}.create-item-form input,.create-item-form select{border:1px solid #bfd4e8;border-radius:8px;padding:8px 9px;width:100%;min-width:0}.create-item-form button{border:0;border-radius:8px;padding:9px 10px;font-weight:700;background:#0f6ab8;color:#fff;cursor:pointer;min-width:0}.create-item-form button:disabled{opacity:.6;cursor:not-allowed}.month-category-totals{list-style:none;padding-left:0;margin:0}.month-category-totals li{display:flex;justify-content:space-between;gap:8px;padding:10px 0;border-bottom:1px solid #e3edf8}.month-category-totals li:last-child{border-bottom:0}.create-category-form label{display:grid;gap:4px;font-size:.85rem;color:#2d4b67}.create-category-form input,.create-category-form select{border:1px solid #bfd4e8;border-radius:8px;padding:8px 9px}.create-category-form button{border:0;border-radius:8px;padding:9px 10px;font-weight:700;background:#0f6ab8;color:#fff;cursor:pointer}.category-groups{margin-top:12px}.category-groups h6{margin:0 0 8px;color:#2d4b67}.items-subtitle{margin:8px 0 4px;color:#53708b;font-size:.78rem;text-transform:uppercase}.category-group{border-top:1px solid #e3edf8;padding-top:12px;margin-top:12px;min-width:0}.category-header{display:flex;justify-content:space-between;gap:8px;min-width:0;flex-wrap:wrap}.category-header.editable{align-items:center}.category-title-edit{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.category-title-edit input{border:1px solid #bfd4e8;border-radius:8px;padding:6px 9px;font-weight:600;color:#1f3f5f;min-width:0;width:100%}.category-meta{display:flex;align-items:center;gap:8px}.type-badge{font-size:.75rem;color:#2f5d84;background:#e7f0f9;border:1px solid #c9ddee;border-radius:999px;padding:3px 8px}.category-group ul{list-style:none;padding-left:0;margin-top:6px}.category-group li{display:block;padding:4px 0}.item-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.item-line{display:block;min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#2d4b67;font-size:.86rem}.item-row .inline-action{padding:4px 8px;font-size:.72rem;border-radius:6px;min-width:0;line-height:1.1;white-space:nowrap}.entry-edit-row{display:grid;grid-template-columns:1.2fr .8fr .9fr auto auto;gap:10px;align-items:center}.entry-edit-row input{border:1px solid #bfd4e8;border-radius:8px;padding:7px 9px}.empty{margin:0;color:#587089;font-size:.88rem}.add-form-wrapper{background:#fff;border:1px solid #d8e6f5;border-radius:16px;padding:16px;height:fit-content}.add-form{margin-top:10px;display:grid;gap:10px}.add-form label{display:grid;gap:4px;color:#2d4b67;font-size:.9rem}.add-form input,.add-form select{border:1px solid #bfd4e8;border-radius:10px;padding:10px;font-size:.95rem}.add-form button{border:0;border-radius:10px;padding:10px 12px;font-weight:700;background:linear-gradient(90deg,#0f6ab8,#2296bc);color:#fff;cursor:pointer}.account-row{margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap;position:relative}.secondary-button{border:1px solid #bfd4e8;border-radius:8px;padding:7px 10px;background:#fff;color:#1f4f78;font-weight:700;cursor:pointer}.options-menu,.options-trigger{position:relative}.options-dropdown{position:absolute;right:0;top:calc(100% + 4px);z-index:10;display:grid;gap:6px;min-width:170px;padding:8px;border:1px solid #bfd4e8;border-radius:10px;background:#fff;box-shadow:0 8px 18px #10355a1f}.options-dropdown .secondary-button{width:100%;text-align:left}.password-form{margin-top:8px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:end}.password-form label{display:grid;gap:4px;color:#2d4b67;font-size:.85rem}.password-form input{border:1px solid #bfd4e8;border-radius:8px;padding:8px 9px}@media(max-width:900px){.app{padding:10px}.global-logo-inner{padding:8px 10px}.global-logo{width:88px;margin-left:-2px}.panel-grid{grid-template-columns:1fr}.source-list{grid-template-columns:1fr;gap:8px}.source-card.closed{aspect-ratio:auto}.source-card.closed .source-numbers{grid-template-columns:1fr}.source-card.closed .source-header{grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"head" "nums" "trend";gap:4px}.mini-trend{height:auto}.source-detail,.create-category-form,.create-item-form,.category-split-grid,.category-title-edit,.entry-edit-row{grid-template-columns:1fr}.create-item-form button,.create-category-form button,.password-form,.inline-action,.inline-danger{width:100%}.item-row .inline-action{width:auto;flex:0 0 auto}.password-form{grid-template-columns:1fr}.account-row{flex-wrap:nowrap;gap:6px;overflow:visible;min-width:0}.account-row small{white-space:nowrap;font-size:.74rem}.account-row .secondary-button{flex:0 0 auto;white-space:nowrap;font-size:.74rem;padding:5px 7px}.options-dropdown{right:0;min-width:150px;max-width:calc(100vw - 24px)}.summary-net-value-label{font-size:8px}.summary-net-month-label{font-size:8.4px}}@media(max-width:1200px)and (min-width:901px){.create-item-form,.create-category-form{grid-template-columns:repeat(3,minmax(0,1fr))}}
