:root{color:#102023;background:#f6f3ed;font-family:Hiragino Sans,Yu Gothic UI,Yu Gothic,Meiryo,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;background:#f6f3ed}body[data-modal-open=true]{overscroll-behavior:none}button,input,select,textarea{font:inherit}button{min-height:48px;border:0;border-radius:8px;background:#108577;color:#fff;font-weight:800}button:disabled{opacity:.62}.auth-screen,.app-shell{min-height:100vh;max-width:430px;margin:0 auto;background:#fffdf8}.auth-screen{display:grid;align-content:start;gap:16px;padding:24px 16px}.app-shell{position:relative;padding-bottom:88px;box-shadow:0 16px 40px #1f29331a}.topbar{position:sticky;top:0;z-index:10;padding:18px 16px 12px;border-bottom:1px solid #ded8cf;background:#fffdf8f7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.eyebrow{margin:0 0 4px;color:#0f766e;font-size:12px;font-weight:800}h1,h2,h3,p,dl{margin:0}h1{font-size:22px;line-height:1.25}h2{font-size:17px}.member-row{display:flex;gap:8px;margin-top:14px}.member-row.align-right{justify-content:flex-end;margin-top:-30px}.chip{min-height:34px;border:1px solid #ded8cf;border-radius:999px;padding:8px 12px;background:#fffdf8;color:#1f2933;font-size:13px;font-weight:800}.chip.active{border-color:#0f766e;background:#0f766e;color:#fff}.user-chip{width:auto;min-height:34px;cursor:pointer}.screen{display:grid;gap:12px;padding:16px}.detail-screen{padding-top:12px}.panel,.card,.summary-card{border:1px solid #ded8cf;border-radius:8px;background:#fffdf8}.panel{display:grid;gap:12px;margin-top:16px;padding:18px}.panel p,.empty,.setup-list dt{color:#58656b;font-size:14px;line-height:1.65}.small{color:#58656b;font-size:12px;line-height:1.5}.detail-filterbar{position:sticky;top:69px;z-index:9;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;padding:0 16px 8px;border-bottom:1px solid #ded8cf;background:#fffdf8f7}.detail-filterbar label,.date-filter-grid label{display:grid;gap:4px}.detail-filterbar span,.date-filter-grid span{color:#58656b;font-size:11px;font-weight:800}.detail-filterbar select{min-height:44px;padding:8px 10px}.project-tab-row{display:grid;grid-auto-columns:34%;grid-auto-flow:column;gap:8px;margin-right:-16px;margin-left:-16px;padding:0 16px 2px;overflow-x:auto;scrollbar-width:none}.project-tab-row::-webkit-scrollbar{display:none}.project-tab{container-type:inline-size;display:grid;gap:4px;min-height:58px;border:1px solid #ded8cf;border-radius:8px;padding:10px;background:#fffdf8;color:#102023;text-align:left}.project-tab.active{border-color:#a8d9d1;background:#d9f3ed}.project-tab strong{overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.project-tab span{color:#53637a;overflow:hidden;font-size:clamp(10px,10cqw,12px);font-weight:800;text-overflow:clip;white-space:nowrap}.date-filter-grid{display:grid;grid-template-columns:112px 112px 58px;gap:4px;align-items:end;justify-content:space-between}.date-filter-grid label{min-width:0}.date-filter-grid input{min-height:32px;border-radius:6px;padding:4px 6px;font-size:12px;letter-spacing:0}.date-filter-grid.in-modal{grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}.detail-search-button{min-height:42px;border-radius:999px;background:#e8e1d6;color:#102023}.period-button{min-height:32px;border-radius:6px;padding:0 4px;background:#e8e1d6;color:#102023;font-size:12px;white-space:nowrap}.compact-field{gap:6px}.detail-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.neutral-action,.danger-action{color:#102023}.neutral-action{background:#e8e1d6}.danger-action{background:#fae4dc;color:#d85f45}.aggregate-list{display:grid}.aggregate-list div{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid #eee8df}.aggregate-list div:last-child{border-bottom:0}.aggregate-list dt{color:#102023}.aggregate-list dd{margin:0;font-weight:800}.csv-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.setup-list.compact{gap:0}.category-breakdown{display:grid;grid-template-columns:96px minmax(0,1fr);gap:14px;align-items:center}.pie-chart{width:96px;height:96px;border:10px solid #fffdf8;border-radius:50%;box-shadow:inset 0 0 0 1px #ded8cf,0 0 0 1px #ded8cf}.category-list{display:grid;gap:8px}.category-list div{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:7px;align-items:center;font-size:12px}.category-list strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-list em{color:#58656b;font-style:normal;font-weight:800}.dot{width:10px;height:10px;border-radius:999px}.income-bg{background:#0f766e}.expense-bg{background:#d85f45}.settlement-card{display:grid;gap:14px}.settlement-card>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px}.settlement-card>div:first-child span{color:#58656b;font-size:13px;font-weight:800}.settlement-card>div:first-child strong{font-size:18px}.share-bars{display:grid;gap:10px}.share-bar{display:grid;gap:6px}.share-bar>div:first-child{display:flex;justify-content:space-between;gap:12px;font-size:13px}.share-track{height:8px;overflow:hidden;border-radius:999px;background:#eee8df}.share-track span{display:block;height:100%;border-radius:inherit;background:#0f766e}.percent-input{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.percent-input span{font-weight:800}.error-text{color:#d85f45;font-weight:800}.attachment-preview{display:block;width:100%;max-height:180px;object-fit:contain;border:1px solid #ded8cf;border-radius:8px;background:#fffdf8}.attachment-preview.large{margin-top:12px;max-height:260px}.attachment-preview-button{display:block;width:100%;padding:0;border:0;background:transparent;text-align:left}.image-preview-backdrop{position:fixed;z-index:1000;margin:0;padding:0;overflow:hidden;overscroll-behavior:none;touch-action:none;background:#102023d1}.image-preview-fullscreen{position:absolute;inset:0;min-width:0;min-height:0;box-sizing:border-box;padding:0;border:0;border-radius:0;display:grid;place-items:center;overflow:hidden;background:transparent;touch-action:none}.image-preview-fullscreen img{display:block;width:auto;height:auto;min-width:0;min-height:0;object-fit:contain;border-radius:8px;background:#fffdf8}.error-panel{border-color:#f3b5a8}.copy-box{display:grid;gap:6px;padding:12px;border:1px solid #ded8cf;border-radius:8px;background:#f7f1e8}.copy-box span{color:#58656b;font-size:12px;font-weight:900}.copy-box code{overflow-wrap:anywhere;color:#102023;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px}.condition-list{display:grid;gap:6px;margin-top:12px}.condition-list span{padding:8px 10px;border-radius:8px;background:#f7f1e8;color:#58656b;font-size:12px;font-weight:800}.csv-fallback{display:grid;gap:8px;margin-top:12px;padding:12px;border:1px solid #ded8cf;border-radius:8px;background:#fffdf8}.summary-loop{position:relative;height:clamp(172px,44vw,188px);margin-right:-16px;margin-left:-16px;overflow:hidden;touch-action:pan-y}.summary-track{position:relative;height:100%}.summary-track.single{height:100%}.summary-slide{position:absolute;top:0;bottom:0;display:block;width:84%;min-height:0;padding:0;border:0;border-radius:8px;background:transparent;color:inherit;text-align:left;touch-action:pan-y;transition:left .16s ease,opacity .16s ease,transform .16s ease}.summary-slide.prev{left:calc(-76% - 8px)}.summary-slide.active{left:8%}.summary-slide.next{left:calc(92% + 8px)}.summary-track.single .summary-slide.active{left:16px;width:calc(100% - 32px)}.summary-slide.prev,.summary-slide.next{opacity:.98}.summary-slide.active{cursor:grab}.summary-slide:focus-visible{outline:3px solid rgba(15,118,110,.28);outline-offset:2px}.summary-card{display:grid;gap:10px;height:100%;min-height:0;padding:12px}.summary-card.dark{border-color:#1b3338;background:#1c343a;color:#fff}.card-head,.section-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.card-head p{margin-top:5px;color:#6b7a86;font-size:11px}.dark .card-head p{color:#bdd0d3}.status-badge{flex:0 0 auto;border-radius:999px;padding:6px 9px;background:#f7e7bd;color:#936300;font-size:12px;font-weight:800}.amount-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.amount-tile{container-type:inline-size;display:grid;gap:4px;min-width:0;padding:10px;border-radius:8px;background:#ffffff1f}.amount-grid.light .amount-tile{background:#f7f3eb}.amount-tile span{color:#d4e4e6;font-size:11px;font-weight:800}.amount-grid.light .amount-tile span{color:#58656b}.amount-tile strong{overflow:hidden;font-size:clamp(9px,13cqw,15px);line-height:1.15;text-overflow:clip;white-space:nowrap}.income{color:#008878}.expense{color:#d85f45}.profit{color:#2d5b91}.dark .income{color:#6be0d1}.dark .expense{color:#ff9b82}.dark .profit{color:#9bc7ff}.summary-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.summary-footer p{min-width:0;overflow:hidden;color:#6b7a86;font-size:11px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.dark .summary-footer p{color:#bdd0d3}.count-badge,.nav-badge{display:grid;place-items:center;min-width:24px;height:24px;border-radius:999px;background:#ffdcd3;color:#d85f45;font-size:12px;font-weight:900}.top-actions,.card{display:grid;gap:12px;padding:14px}.top-actions{padding-right:14px;padding-left:14px}.wide-action{border-radius:999px}.button-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.expense-submit{background:#d85f45}.stack{display:grid;gap:10px}.transaction-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 12px;padding:13px;border:1px solid #ded8cf;border-radius:8px;background:#fffdf8;cursor:pointer}.transaction-card strong{min-width:0;overflow:hidden;font-size:16px;text-overflow:ellipsis;white-space:nowrap}.transaction-card>.income,.transaction-card>.expense{align-self:start;min-width:max-content;font-size:clamp(13px,4vw,16px);white-space:nowrap}.transaction-card p,.pill-row{grid-column:1 / -1}.transaction-card p{color:#58656b;font-size:12px;line-height:1.5}.pill-row{display:flex;flex-wrap:wrap;gap:6px}.mini-pill{border-radius:999px;padding:5px 8px;background:#f0ebe3;color:#58656b;font-size:11px;font-weight:800}.mini-pill.approved{background:#d9f3ed;color:#0f766e}.mini-pill.pending{background:#f7e7bd;color:#936300}.mini-pill.rejected{background:#ffe4dc;color:#c54834}.empty{border:1px dashed #ded8cf;border-radius:8px;padding:18px;text-align:center}.form{display:grid;gap:12px}.field{display:grid;gap:6px;min-width:0}.field span{color:#58656b;font-size:12px;font-weight:800}input,select,textarea{width:100%;max-width:100%;min-width:0;min-height:46px;border:1px solid #ded8cf;border-radius:8px;padding:10px 12px;background:#fffdf8;color:#102023}input[type=date]{display:block;width:100%;min-width:0;max-width:100%;-webkit-appearance:none;appearance:none;line-height:1.2}input[type=date]::-webkit-date-and-time-value{min-width:0;text-align:left}textarea{min-height:96px;resize:vertical}.two-col{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}.form-error{padding:12px;border:1px solid #f3b5a8;border-radius:8px;background:#fff4ef;color:#c54834;font-size:14px;font-weight:800}.rejection-note{display:grid;gap:6px;padding:12px;border:1px solid #f3b5a8;border-radius:8px;background:#fff4ef}.rejection-note strong{color:#c54834;font-size:13px}.rejection-note p{margin:0;color:#102023;font-size:14px;line-height:1.6;overflow-wrap:anywhere}.subtle-button{min-height:36px;border:1px solid #ded8cf;border-radius:999px;padding:7px 12px;background:#fffdf8;color:#102023;font-size:13px}.toast{margin:12px 16px 0;padding:10px 12px;border:1px solid #a8d9d1;border-radius:8px;background:#d9f3ed;color:#0f766e;font-size:13px;font-weight:800}.setup-list{display:grid;gap:10px}.setup-list div{display:flex;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid #eee8df}.setup-list div:last-child{padding-bottom:0;border-bottom:0}.setup-list dd{margin:0;font-weight:800;font-size:clamp(13px,4.2vw,18px);text-align:right;white-space:nowrap}.entry-type-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.entry-type-tabs button{display:grid;gap:4px;min-height:66px;border:1px solid #ded8cf;padding:9px 6px;background:#fffdf8;color:#102023;line-height:1.2}.entry-type-tabs button.active{border-color:#0f766e;background:#0f766e;color:#fff}.entry-type-tabs button.active.expense-tab{border-color:#d85f45;background:#d85f45}.entry-type-tabs small{font-size:10px;line-height:1.25;white-space:nowrap}.entry-type-tabs span{font-size:16px;line-height:1.25}.entry-type-banner{display:grid;gap:4px;padding:14px;border:1px solid #a8d9d1;border-radius:8px;background:#d9f3ed}.entry-type-banner.entry-expense{border-color:#f0b9aa;background:#fae4dc}.entry-type-banner span{color:#58656b;font-size:12px}.approval-tabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.approval-tabs button{display:grid;place-items:center;gap:5px;min-height:48px;border:1px solid #ded8cf;background:#fffdf8;color:#102023;font-size:12px}.approval-tabs button.active{border-color:#a8d9d1;background:#d9f3ed;color:#0f766e}.approval-tabs b,.pill{display:inline-grid;place-items:center;min-width:22px;height:22px;border-radius:999px;background:#ffdcd3;color:#d85f45;font-size:11px}.settings-summary-card{width:100%;color:#102023;text-align:left}.clickable-card{cursor:pointer}.compact-action{width:auto;min-height:34px;padding:0 12px;font-size:13px}.settings-count-row{display:flex;justify-content:space-between;gap:12px;color:#58656b;font-size:12px}.dialog-backdrop{position:fixed;inset:0;z-index:40;display:grid;align-items:end;padding:16px;overflow:hidden;overscroll-behavior:contain;touch-action:none;background:#1020236b}.dialog-backdrop:has(.dialog){align-items:center;background:#1020238f}.dialog-backdrop:has(.detail-modal){align-items:end;background:#1020236b}.dialog-backdrop.nested{z-index:50;align-items:center;background:#1020238f}.dialog,.detail-modal{display:grid;gap:14px;width:min(100%,430px);max-height:min(86vh,720px);margin:0 auto;overflow:auto;overscroll-behavior:contain;touch-action:pan-y;-webkit-overflow-scrolling:touch;border-radius:12px 12px 8px 8px;padding:16px;background:#fffdf8}.modal-head{display:flex;justify-content:space-between;gap:12px}.history-version-select{padding:10px;border:1px solid #e7dfd3;border-radius:8px;background:#fbf7ef}.icon-close{width:42px;height:42px;min-width:42px;min-height:42px;padding:0;border-radius:999px;background:#e8e1d6;color:#102023;font-size:20px;line-height:1;display:inline-grid;place-items:center;flex:0 0 42px}.detail-list{display:grid;gap:0}.detail-list div{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid #eee8df}.detail-list dt{color:#58656b;font-size:13px;font-weight:800}.detail-list dd{margin:0;text-align:right;white-space:nowrap}.detail-list dt+dd{max-width:68%}.detail-list .comment-row{display:grid;gap:6px}.detail-list .comment-row dd{max-width:100%;text-align:left;white-space:normal;overflow-wrap:anywhere}.diff-section{display:grid;gap:10px;padding:12px;border:1px solid #e7dfd3;border-radius:8px;background:#fbf7ef}.diff-section h3{margin:0;font-size:15px}.diff-list{display:grid;gap:8px}.diff-list>div{display:grid;gap:4px;padding-bottom:8px;border-bottom:1px solid #eee8df}.diff-list>div:last-child{padding-bottom:0;border-bottom:0}.diff-list strong{color:#58656b;font-size:12px}.diff-list p{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:8px;margin:0;align-items:center}.diff-list span{min-width:0;overflow-wrap:anywhere}.diff-list b{color:#0f766e}.previous-rejection-comment{display:grid;gap:6px;padding:10px;border-radius:8px;background:#fff4ef}.previous-rejection-comment strong{color:#c54834;font-size:12px}.previous-rejection-comment p{margin:0;font-size:13px;line-height:1.6;overflow-wrap:anywhere}.dialog-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.dialog-actions.single{grid-template-columns:1fr}.dialog-actions>:only-child{grid-column:1 / -1}.dialog-actions>:nth-child(3):last-child{grid-column:1 / -1}.detail-modal>.dialog-actions:last-of-type{grid-template-columns:1fr}.inline-confirm{display:grid;gap:12px;padding:12px;border:1px solid #ded8cf;border-radius:8px;background:#f7f3eb}.settings-edit-list{display:grid;gap:10px}.settings-edit-list>div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;border:1px solid #ded8cf;border-radius:8px}.settings-row-actions{display:flex;align-items:center;gap:6px}.settings-row-actions .neutral-action{width:auto;min-height:42px;padding:0 12px}.round-action{display:grid;place-items:center;width:36px;min-width:36px;min-height:36px;border:1px solid #ded8cf;border-radius:999px;background:#fffdf8;color:#102023;font-size:14px}.round-action:disabled{opacity:.35}.modal-action-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.modal-action-row.single{grid-template-columns:1fr}.modal-action-row .neutral-action{width:auto;min-width:112px;padding:0 14px}.check-row{display:flex;align-items:center;gap:8px;color:#102023;font-weight:800}.check-row input{width:18px;height:18px;accent-color:#128a7a}.search-section{display:grid;gap:10px;padding:12px;border:1px solid #eee8df;border-radius:8px;background:#fffdf8}.compact-title{align-items:center}.compact-title h3{margin:0;font-size:15px}.search-section-actions{display:flex;align-items:center;gap:8px}.search-section-actions .compact-action:disabled{opacity:.45}.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.option-check{min-width:0;border:1px solid #eee8df;border-radius:8px;padding:9px;background:#fbf7ef;font-size:13px}.suffix-input{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.suffix-input b{color:#58656b}.bottom-nav{position:fixed;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(5,1fr);max-width:430px;margin:0 auto;padding:8px 10px 10px;border-top:1px solid #ded8cf;background:#fffdf8f5}.bottom-nav button{position:relative;display:grid;place-items:center;gap:3px;min-height:46px;border:0;border-radius:8px;background:transparent;color:#53637a;font-size:11px;font-weight:800}.bottom-nav button.active{background:#d9f3ed;color:#0f766e}.nav-badge{position:absolute;top:2px;right:12px;min-width:18px;height:18px;font-size:10px}
