*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4CAF50;--primary-dark: #388E3C;--primary-light: #81C784;--primary-bg: #E8F5E9;--accent: #FF7043;--text-main: #212121;--text-sub: #757575;--border: #E0E0E0;--bg: #F5F5F5;--white: #FFFFFF;--shadow: 0 2px 12px rgba(0,0,0,.08);--radius: 12px}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text-main);min-height:100vh}#app{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.main-layout{display:flex;flex-direction:column;min-height:100vh}.top-nav{background:linear-gradient(135deg,#2e7d32,#4caf50,#66bb6a);color:#fff;padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #2e7d324d;position:sticky;top:0;z-index:100}.nav-title{font-size:18px;font-weight:700;letter-spacing:1px;cursor:pointer}.nav-right{display:flex;align-items:center;gap:12px}.nav-user{font-size:14px;opacity:.9}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;border-top:1px solid var(--border);box-shadow:0 -2px 8px #0000000f;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;cursor:pointer;transition:all .2s;color:var(--text-sub);font-size:11px;gap:3px;min-height:56px}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item .nav-icon{font-size:22px;line-height:1}.page-content{flex:1;padding:7px 12px 72px;max-width:800px;margin:0 auto;width:100%}.search-bar{background:#fff;border-radius:var(--radius);padding:12px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;gap:8px;align-items:center;flex-wrap:wrap}.date-filter-row{align-items:center}.date-filter-label{font-size:13px;color:var(--text-sub);white-space:nowrap}.date-filter-row .date-filter-label+.el-date-editor{margin-left:2px}.date-filter-wrap{flex-wrap:wrap}.btn-category-entry{white-space:nowrap}.filter-bar-wrap{background:#fff;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;box-sizing:border-box;overflow:hidden}.filter-row{display:flex;align-items:center;gap:6px;width:100%;box-sizing:border-box}.filter-row:first-child,.filter-row-search{flex-wrap:nowrap}.filter-row-btns{flex-wrap:nowrap;gap:8px;width:100%}.filter-row-btns .filter-btn-clear,.filter-row-btns .filter-btn-search{flex:1;min-width:0}.filter-label{font-size:11px;color:var(--text-sub);white-space:nowrap;flex-shrink:0}.filter-date-group{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow:hidden}.filter-date-picker{flex:1 1 0;min-width:0;max-width:none;width:0}.filter-date-picker .el-input__wrapper{padding:0 6px!important}.filter-date-picker .el-input__inner{font-size:12px!important;text-align:center;min-width:0}.filter-date-picker .el-input__prefix{display:none}.filter-bar-wrap .filter-keyword-input .el-input__wrapper,.filter-bar-wrap .filter-date-picker .el-input__wrapper{min-height:var(--el-input-height, var(--el-component-size))!important;height:var(--el-input-height, var(--el-component-size))!important;border-radius:var(--el-input-border-radius, var(--el-border-radius-base))!important}@media (min-width: 768px){.filter-date-picker .el-input__inner{font-size:14px!important}.filter-date-picker .el-input__wrapper{padding:0 10px!important}}.filter-date-sep{color:#bbb;font-size:13px;flex-shrink:0}.filter-keyword-input{flex:5 1 0;min-width:0;max-width:none}.filter-type-select{flex:3 1 0;min-width:0}.filter-type-select .el-select__wrapper{min-width:0!important}.filter-category-select{flex:3 1 0;min-width:0}.filter-category-select .el-select__wrapper{min-width:0!important}.filter-bar-wrap .filter-row-search .filter-type-select .el-select__wrapper,.filter-bar-wrap .filter-row-search .filter-category-select .el-select__wrapper{min-height:var(--el-input-height, var(--el-component-size))!important;height:var(--el-input-height, var(--el-component-size))!important;border-radius:var(--el-input-border-radius, var(--el-border-radius-base))!important;padding:1px 11px!important;font-size:var(--el-font-size-base)!important}.filter-bar-wrap .filter-row-search .filter-type-select .el-select__placeholder,.filter-bar-wrap .filter-row-search .filter-category-select .el-select__placeholder,.filter-bar-wrap .filter-row-search .filter-type-select .el-select__input,.filter-bar-wrap .filter-row-search .filter-category-select .el-select__input{font-size:inherit!important}.filter-bar-wrap .filter-row-search .filter-type-select .el-select__placeholder,.filter-bar-wrap .filter-row-search .filter-category-select .el-select__placeholder{color:var(--el-text-color-placeholder, #c0c4cc)!important}.filter-btn-search{background:#4caf50!important;color:#fff!important;border-color:#4caf50!important;border-radius:calc(var(--radius) * .8)!important;font-weight:600;padding:0 18px;white-space:nowrap}.filter-btn-search:hover{background:#43a047!important;border-color:#43a047!important}.filter-btn-clear{background:#ff9800!important;color:#fff!important;border-color:#ff9800!important;border-radius:calc(var(--radius) * .8)!important;font-weight:600;padding:0 18px;white-space:nowrap}.filter-btn-clear:hover{background:#f57c00!important;border-color:#f57c00!important}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.summary-cards.summary-cards-2col{grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}.summary-cards.summary-cards-row{display:flex;flex-direction:row;gap:8px;align-items:stretch}.summary-cards.summary-cards-row .summary-card{flex:1;min-width:0}.summary-stats-bar{display:flex;flex-direction:row;gap:8px;align-items:stretch;margin-bottom:10px;flex-wrap:nowrap;min-width:0;overflow-x:auto}.summary-stats-bar .summary-card{flex:1;min-width:0}.summary-stats-bar .stats-count-box{display:flex;flex-direction:column;justify-content:center;align-items:stretch;padding:5px 10px;gap:0;flex:0 1 auto;min-width:0;max-width:100%}.stats-count-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:6px;padding:2px 0;white-space:nowrap}.stats-count-item .label{font-size:11px;color:var(--text-sub);white-space:nowrap;flex-shrink:0}.stats-count-item .value{font-size:12px;font-weight:700;color:var(--primary-dark);white-space:nowrap;line-height:1.2;min-width:0;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}.summary-stats-bar .stats-count-box.stats-count-digits-3 .stats-count-item .value{font-size:10px}.summary-stats-bar .stats-count-box.stats-count-digits-4 .stats-count-item .value{font-size:9px}.summary-stats-bar .stats-count-item .label{margin-bottom:0;line-height:1.2}.summary-stats-bar .summary-card.summary-card-compact{flex:1 0 min-content;min-width:min-content}.stats-divider{height:1px;background:var(--border, #eee);margin:2px 0}.summary-card-col{display:flex;flex-direction:column;gap:10px}.summary-card-col .summary-card{flex:1}.summary-card.summary-card-compact{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:6px;text-align:center}.summary-card.summary-card-compact .label{font-size:11px;color:var(--text-sub);margin-bottom:2px;white-space:nowrap}.summary-card.summary-card-compact .value{font-size:16px;font-weight:700;color:var(--primary-dark);white-space:nowrap;overflow:visible;text-overflow:clip;max-width:none}.summary-card{background:#fff;border-radius:var(--radius);padding:16px 14px;text-align:center;box-shadow:var(--shadow)}.summary-card .label{font-size:13px;color:var(--text-sub);margin-bottom:6px;white-space:nowrap}.summary-card .value{font-size:22px;font-weight:700;color:var(--primary-dark);white-space:nowrap}.summary-card .value.red,.summary-stats-bar .summary-card.summary-card-compact .value.summary-stat-gift-out{color:#e53935}.summary-stats-bar .summary-card.summary-card-compact .value.summary-stat-gift-in{color:#2e7d32}.summary-card.summary-card-compact.summary-card--estimate-foot{position:relative;padding-bottom:18px}.summary-card .summary-estimate-note{position:absolute;left:6px;right:6px;bottom:4px;text-align:center;font-size:10px;line-height:1.2;color:var(--text-sub);white-space:normal;overflow-wrap:break-word;font-weight:500;font-variant-numeric:tabular-nums}.gift-amount-row{display:flex;align-items:center;gap:10px;width:100%}.gift-amount-row .gift-amount-input{flex:1;min-width:0}.gift-amount-row .gift-estimate-check.el-checkbox{flex-shrink:0;margin-right:0;white-space:nowrap}.summary-card.summary-card--gift-total{position:relative}.summary-card.summary-card--gift-total.summary-card--estimate-foot{padding-bottom:22px}.summary-group-meta-amount,.summary-group-meta-gift-out{color:#e53935;font-weight:600;font-variant-numeric:tabular-nums}.summary-group-meta-gift-in{color:#2e7d32;font-weight:600;font-variant-numeric:tabular-nums}.summary-group-list{display:flex;flex-direction:column;gap:16px}.summary-group{border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #00000012}.summary-group-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;padding:8px 14px;background:#f5f7fa;border-bottom:1px solid #e4e7ed}.summary-group-title{font-size:15px;font-weight:600;color:#303133}.page-expense .summary-group-title,.page-gift .summary-group-header .summary-group-title{font-size:12px}.page-gift .summary-group-header:has(.summary-group-meta--gift-totals){column-gap:clamp(12px,2.5ch,28px);row-gap:8px}.summary-group-meta{font-size:13px;color:#909399}@media (max-width: 767px){.page-gift .summary-group-header:has(.summary-group-meta--gift-totals){flex-wrap:nowrap;align-items:center;justify-content:flex-start;column-gap:clamp(6px,1.75ch,14px);row-gap:6px;padding-left:max(10px,env(safe-area-inset-left,0px));padding-right:max(10px,env(safe-area-inset-right,0px));overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin}.page-gift .summary-group-header:has(.summary-group-meta--gift-totals)::-webkit-scrollbar{height:4px}.page-gift .summary-group-header:has(.summary-group-meta--gift-totals)::-webkit-scrollbar-thumb{background:#0000002e;border-radius:2px}.page-gift .summary-group-header:has(.summary-group-meta--gift-totals) .summary-group-title{flex:0 0 auto;flex-shrink:0}.page-gift .summary-group-meta.summary-group-meta--gift-totals{line-height:1.35;white-space:nowrap;font-variant-numeric:tabular-nums;letter-spacing:-.02em;flex:0 0 auto;text-align:left;overflow-x:visible}.page-gift .summary-group-meta--gift-totals .summary-group-meta-gift-out,.page-gift .summary-group-meta--gift-totals .summary-group-meta-gift-in{font-size:inherit;font-weight:600}}.summary-card.summary-card-amount{display:flex;flex-direction:column;justify-content:center;padding:14px 12px}.summary-card.summary-card-dual{display:flex;flex-direction:column;justify-content:center;gap:0;padding:14px 16px;text-align:left}.dual-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.dual-label{font-size:14px;color:var(--text-sub);white-space:nowrap}.dual-value{font-size:22px;font-weight:700;color:var(--primary-dark);white-space:nowrap}.dual-divider{height:1px;background:var(--border);margin:2px 0}.record-list{display:flex;flex-direction:column;gap:10px}.record-card{background:#fff;border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s;overflow-x:auto;overflow-y:visible;min-width:0}.record-card:active{transform:scale(.98)}.page-expense .record-card,.page-gift .record-card{padding-left:calc(14px * .7);padding-right:calc(14px * .7)}.record-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;gap:8px;flex-wrap:nowrap;min-width:0}.record-row1-left{display:flex;align-items:center;gap:2px;flex-wrap:nowrap;white-space:nowrap;overflow:visible;flex:1 1 auto;min-width:115px}.record-datetime{font-size:10px;color:var(--text-main);font-weight:500;display:inline-flex;align-items:center;gap:2px;white-space:nowrap;flex-shrink:0;overflow:visible}.record-datetime:before{content:"";display:inline-block;width:13px;height:13px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' fill='%23E8F5E9' stroke='%234CAF50' stroke-width='1.8'/%3E%3Cline x1='16' y1='2' x2='16' y2='6' stroke='%234CAF50' stroke-width='2' stroke-linecap='round'/%3E%3Cline x1='8' y1='2' x2='8' y2='6' stroke='%234CAF50' stroke-width='2' stroke-linecap='round'/%3E%3Cline x1='3' y1='10' x2='21' y2='10' stroke='%234CAF50' stroke-width='1.5'/%3E%3Ccircle cx='8' cy='15' r='1.2' fill='%234CAF50'/%3E%3Ccircle cx='12' cy='15' r='1.2' fill='%234CAF50'/%3E%3Ccircle cx='16' cy='15' r='1.2' fill='%234CAF50'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0;margin-right:2px}.record-operator{font-size:10px;color:var(--text-sub);display:inline-flex;align-items:center;gap:1px;margin-left:3px;white-space:nowrap;flex-shrink:0;overflow:visible}.record-operator:before{content:"";display:inline-block;width:13px;height:13px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='8' r='4' fill='%23B3E5FC' stroke='%230288D1' stroke-width='1.5'/%3E%3Cpath d='M4 20c0-4 3.6-7 8-7s8 3 8 7' fill='%23E1F5FE' stroke='%230288D1' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0}.record-row2{display:flex;align-items:center;gap:6px;justify-content:space-between}.record-row3{display:none}.record-title{font-size:15px;font-weight:600;color:var(--text-main);flex:1;display:flex;align-items:baseline;gap:6px}.record-sub{font-size:12px;font-weight:400;color:var(--text-sub)}.record-amount{font-size:14px;font-weight:700;color:#e53935;white-space:nowrap;display:inline-block;text-align:right;line-height:1;flex-shrink:0;flex:0 0 auto;max-width:50%;min-width:0;overflow:visible;margin-left:4px}.record-amount.income{color:var(--primary-dark)}.page-gift .record-row1-amount-wrap{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;min-width:0}.page-gift .record-row1-amount-wrap .record-amount{margin-left:0}.page-gift .record-estimate-badge{display:inline-flex;align-items:center;justify-content:center;width:calc(6px + 9px * 1.2);height:calc(6px + 9px * 1.2);padding:2px;border-radius:4px;font-size:9px;font-weight:500;line-height:1.2;white-space:nowrap;flex-shrink:0;box-sizing:border-box;background:#fff0f5;color:#9d174d;border:1px solid #FBCFE8}.record-remark{font-size:11px;color:#999}.record-tag{background:#e8f5e9;color:#2e7d32;padding:2px 8px;border-radius:4px;font-size:11px;white-space:nowrap;font-weight:500;border:1px solid #C8E6C9}.record-tag .record-tag-icon{margin-right:3px;font-size:12px}.record-tag-income{background:#e8f5e9;color:#1b5e20;border:1px solid #C8E6C9}.record-tag-out{background:#fff0f5;color:#9d174d;border:1px solid #FBCFE8}.record-tag-empty{background:#f0f0f0;color:#999;border:1px solid #e0e0e0}.record-row2-left{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.record-row2-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:0;flex-shrink:0;margin-right:0}.record-row2-content{font-size:15px;font-weight:600;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-expense .record-row2-content,.page-gift .record-row2-content{font-size:11px!important}.page-expense .record-tag,.page-gift .record-tag{font-size:9px!important;padding:2px 8px!important;border-radius:4px!important;font-weight:500!important;line-height:normal!important}.page-expense .record-tag .record-tag-icon{display:inline-block!important;font-size:10px!important;margin-right:3px!important;line-height:1!important;vertical-align:middle!important}.page-gift .record-tag .record-tag-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:1.1em!important;min-width:1.1em!important;margin-right:3px!important;margin-left:2px!important;font-size:10px!important;line-height:1!important;vertical-align:middle!important;flex-shrink:0!important}.page-gift .record-card-gift .record-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:9px;font-weight:500;line-height:1.2;margin:0;flex-shrink:0;white-space:nowrap;box-sizing:border-box}.page-expense .summary-group .summary-table--period-summary .el-table__body td:first-child .cell{font-size:12px!important}.page-expense .summary-table:not(.summary-table--period-summary) .el-table thead th:first-child .cell,.page-expense .summary-table:not(.summary-table--period-summary) .el-table__body td:first-child .cell{padding-left:12px!important;padding-right:10px!important;display:flex!important;align-items:center!important;flex-wrap:nowrap!important;justify-content:flex-start!important;font-size:12px!important;line-height:1.4!important}.page-expense .summary-table:not(.summary-table--period-summary) .el-table thead th:last-child .cell,.page-expense .summary-table:not(.summary-table--period-summary) .el-table__body td:last-child .cell{padding-left:10px!important;padding-right:12px!important}.page-expense .summary-table:not(.summary-table--period-summary) .el-table__body td:first-child .cell>span{display:inline-flex!important;align-items:center!important;flex-wrap:wrap!important;gap:8px!important;line-height:1.4!important;vertical-align:middle}.page-expense .summary-table:not(.summary-table--period-summary) .cat-table-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:1.35em!important;min-width:1.35em!important;margin-right:0!important;flex-shrink:0!important;font-size:1.2em!important;line-height:1!important;vertical-align:unset!important}.page-gift .summary-table--gift-category-manage .el-table thead th:first-child.el-table__cell .cell,.page-gift .summary-table--gift-category-manage .el-table__body td:first-child.el-table__cell .cell{padding-left:12px!important;padding-right:10px!important;display:flex!important;align-items:center!important;flex-wrap:nowrap!important;justify-content:flex-start!important;font-size:12px!important;line-height:1.4!important}.page-gift .summary-table--gift-category-manage .el-table thead th:last-child .cell,.page-gift .summary-table--gift-category-manage .el-table__body td:last-child .cell{padding-left:10px!important;padding-right:12px!important}.page-gift .summary-table--gift-category-manage .el-table__body td:first-child .cell>span{display:inline-flex!important;align-items:center!important;flex-wrap:wrap!important;gap:8px!important;line-height:1.4!important;vertical-align:middle}.page-gift .summary-table--gift-category-manage .cat-table-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:1.35em!important;min-width:1.35em!important;margin-right:0!important;flex-shrink:0!important;font-size:1.2em!important;line-height:1!important;vertical-align:unset!important}.page-gift .summary-table--gift-category-manage .cat-lock-icon{display:inline-flex!important;align-items:center!important;flex-shrink:0!important;line-height:1!important}.record-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.record-meta{display:flex;gap:12px;font-size:12px;color:var(--text-sub);flex-wrap:wrap}.category-hint{display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:12px;background:#fff8e1;border:1px solid #ffecb3;border-radius:8px;font-size:13px;color:#f57c00}.record-image{margin-top:8px;border-radius:8px;overflow:hidden;max-width:120px}.record-image img{width:100%;height:80px;object-fit:cover;display:block}.camera-icon-btn{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s,transform .2s;margin-top:0}.camera-icon-btn:hover{opacity:.7;transform:scale(1.1)}.camera-icon-btn:hover img{filter:none}.el-overlay-dialog .form-dialog.el-dialog,.form-dialog.el-dialog{border-radius:14px!important;overflow:hidden!important;background:#eff6ff!important;box-shadow:0 8px 40px #1e40af2e!important;border:none!important;padding:0!important;margin:0 auto!important}.form-dialog.el-dialog .el-dialog__header{background:#eff6ff!important;border-bottom:1px solid #DBEAFE!important;padding:18px 20px 12px!important;border-radius:14px 14px 0 0!important;margin-right:0!important}.form-dialog.el-dialog .el-dialog__title{font-size:16px!important;font-weight:700!important;color:#1e40af!important}.form-dialog.el-dialog .el-dialog__headerbtn{top:16px!important;right:16px!important}.form-dialog.el-dialog .el-dialog__body{padding:16px 20px 8px!important;background:#eff6ff!important}.form-dialog.el-dialog .el-dialog__footer{background:#eff6ff!important;border-top:1px solid #DBEAFE!important;padding:10px 20px 18px!important;border-radius:0 0 14px 14px!important}.form-dialog-footer-stack{display:flex;flex-direction:column;width:100%;align-items:stretch}.form-dialog-msg-anchor{position:relative;width:100%;height:0;overflow:visible;flex-shrink:0}.form-dialog-msg-anchor .el-message.el-message--form-dialog-anchor{position:absolute!important;left:50%!important;right:auto!important;top:auto!important;bottom:8px!important;transform:translate(-50%)!important;margin:0!important;max-width:calc(100% - 16px);box-sizing:border-box;pointer-events:auto}.el-overlay-dialog .dialog-gift-out.el-dialog,.dialog-gift-out.el-dialog{background:#fff0f5!important;box-shadow:0 8px 40px #be185d24!important}.dialog-gift-out.el-dialog .el-dialog__header{background:#fff0f5!important;border-bottom-color:#fbcfe8!important}.dialog-gift-out.el-dialog .el-dialog__title{color:#9d174d!important}.dialog-gift-out.el-dialog .el-dialog__body{background:#fff0f5!important}.dialog-gift-out.el-dialog .el-dialog__footer{background:#fff0f5!important;border-top-color:#fbcfe8!important}.dialog-gift-out.el-dialog .el-input__wrapper{box-shadow:0 0 0 1px #fbcfe8 inset!important}.dialog-gift-out.el-dialog .el-input__wrapper:hover{box-shadow:0 0 0 1px #f9a8d4 inset!important}.dialog-gift-out.el-dialog .el-input__wrapper.is-focus{box-shadow:0 0 0 1px #ec4899 inset!important}.dialog-gift-out.el-dialog .el-textarea__inner,.dialog-gift-out.el-dialog .el-select__wrapper,.dialog-gift-out.el-dialog .el-date-editor.el-input__wrapper{box-shadow:0 0 0 1px #fbcfe8 inset!important}.el-overlay-dialog .dialog-gift-in.el-dialog,.dialog-gift-in.el-dialog{background:#fff1f2!important;box-shadow:0 8px 40px #9f123924!important}.dialog-gift-in.el-dialog .el-dialog__header{background:#fff1f2!important;border-bottom-color:#fecdd3!important}.dialog-gift-in.el-dialog .el-dialog__title{color:#881337!important}.dialog-gift-in.el-dialog .el-dialog__body{background:#fff1f2!important}.dialog-gift-in.el-dialog .el-dialog__footer{background:#fff1f2!important;border-top-color:#fecdd3!important}.dialog-gift-in.el-dialog .el-input__wrapper{box-shadow:0 0 0 1px #fecdd3 inset!important}.dialog-gift-in.el-dialog .el-input__wrapper:hover{box-shadow:0 0 0 1px #fda4af inset!important}.dialog-gift-in.el-dialog .el-input__wrapper.is-focus{box-shadow:0 0 0 1px #f43f5e inset!important}.dialog-gift-in.el-dialog .el-textarea__inner,.dialog-gift-in.el-dialog .el-select__wrapper,.dialog-gift-in.el-dialog .el-date-editor.el-input__wrapper{box-shadow:0 0 0 1px #fecdd3 inset!important}.form-dialog.el-dialog .el-form-item{margin-bottom:8px!important}.form-dialog.el-dialog .el-form-item__label{flex-shrink:0!important;min-width:70px!important;padding-right:8px!important;font-size:14px!important;color:#374151!important}.form-dialog.el-dialog .el-form-item__content{min-width:0!important;flex:1!important;overflow:hidden!important}.form-dialog.el-dialog .el-input,.form-dialog.el-dialog .el-select,.form-dialog.el-dialog .el-date-editor{width:100%!important}.form-dialog.el-dialog .el-input__wrapper{background:#fff!important;padding:2px 12px!important;box-shadow:0 0 0 1px #bfdbfe inset!important}.form-dialog.el-dialog .el-input__wrapper:hover{box-shadow:0 0 0 1px #93c5fd inset!important}.form-dialog.el-dialog .el-input__wrapper.is-focus{box-shadow:0 0 0 1px #3b82f6 inset!important}.form-dialog.el-dialog .el-input__inner{padding:6px 0!important;height:36px!important;line-height:36px!important}.form-dialog.el-dialog .form-dialog-line-input.el-input .el-input__wrapper,.form-dialog.el-dialog .form-dialog-line-input.el-autocomplete .el-input .el-input__wrapper{min-height:var(--el-input-height)!important;height:var(--el-input-height)!important;box-sizing:border-box!important}.form-dialog.el-dialog .form-dialog-line-input.el-input .el-input__inner,.form-dialog.el-dialog .form-dialog-line-input.el-autocomplete .el-input .el-input__inner{height:var(--el-input-inner-height)!important;line-height:var(--el-input-inner-height)!important;padding-top:0!important;padding-bottom:0!important}.form-dialog.el-dialog .el-textarea__inner{background:#fff!important;padding:8px 12px!important;box-shadow:0 0 0 1px #bfdbfe inset!important}.form-dialog.el-dialog .el-select__wrapper{background:#fff!important;padding:2px 12px!important;box-shadow:0 0 0 1px #bfdbfe inset!important;min-height:40px!important}.form-dialog.el-dialog .el-date-editor.el-input__wrapper{background:#fff!important;padding:2px 12px!important;box-shadow:0 0 0 1px #bfdbfe inset!important}.dialog-expense .expense-category-grid-wrap,.form-dialog.dialog-expense .expense-category-grid-wrap{--expense-cat-row-h: 46px;--expense-cat-gap: 8px;width:100%!important;margin:0 0 12px!important;padding:3px!important;box-sizing:border-box!important;height:auto!important;overflow:visible!important;display:flex!important;align-items:flex-start!important;justify-content:center!important}.dialog-expense .expense-category-grid-wrap .expense-category-grid,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-grid{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;grid-auto-rows:var(--expense-cat-row-h)!important;gap:var(--expense-cat-gap)!important;padding:0!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important;min-width:0!important}.dialog-expense .expense-category-grid-wrap .expense-category-item,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;width:90%!important;min-width:0!important;max-width:100%!important;justify-self:center!important;align-self:center!important;height:calc(var(--expense-cat-row-h) * .9)!important;min-height:calc(var(--expense-cat-row-h) * .9)!important;max-height:calc(var(--expense-cat-row-h) * .9)!important;padding:4px 2px!important;border-radius:9px!important;border:1px solid var(--border)!important;background:#fafafa!important;color:#212121!important;cursor:pointer!important;transition:all .2s!important;box-sizing:border-box!important;overflow:visible!important;flex:none!important;aspect-ratio:unset!important}.dialog-expense .expense-category-grid-wrap .expense-category-item .cat-icon,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item .cat-icon{font-size:18px!important;line-height:1!important;margin:0 0 2px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important}.dialog-expense .expense-category-grid-wrap .expense-category-item .cat-name,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item .cat-name{font-size:7px!important;color:#212121!important;text-align:center!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;align-self:stretch!important;min-width:0!important;max-width:100%!important;line-height:1.1!important;margin:0!important;flex-shrink:0!important}.dialog-expense .expense-category-grid-wrap .expense-category-item:hover,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item:hover{border-color:var(--primary)!important;background:var(--primary-bg)!important}.dialog-expense .expense-category-grid-wrap .expense-category-item.active,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item.active{border-color:var(--primary)!important;background:var(--primary-bg)!important;color:var(--primary-dark)!important;box-shadow:0 0 0 1px var(--primary)!important}.dialog-expense .expense-category-grid-wrap .expense-category-empty,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-empty{grid-column:1 / -1!important;padding:24px 16px!important;text-align:center!important;color:var(--text-sub)!important;font-size:14px!important;background:#f5f5f5!important;border-radius:10px!important;border:1px dashed var(--border)!important}.form-dialog.dialog-expense .expense-category-form-item.el-form-item{align-items:flex-start!important}.form-dialog.dialog-expense .expense-category-form-item .el-form-item__label{display:none!important;width:0!important;min-width:0!important;margin:0!important;padding:0!important}.form-dialog.dialog-expense .expense-category-form-item .el-form-item__content{padding-left:0!important;padding-right:0!important;margin-left:0!important;box-sizing:border-box!important}.form-dialog.dialog-expense .expense-category-form-item .expense-category-grid-wrap{margin-bottom:0!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap,.form-dialog.dialog-gift-in .gift-category-grid-wrap{width:100%!important;margin:0 0 12px!important;padding:3px!important;box-sizing:border-box!important;height:auto!important;overflow:visible!important;display:flex!important;align-items:flex-start!important;justify-content:center!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-grid,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;grid-auto-rows:52px!important;gap:8px!important;padding:0!important;width:100%!important;box-sizing:border-box!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;width:100%!important;min-width:0!important;max-width:none!important;height:52px!important;min-height:52px!important;max-height:52px!important;aspect-ratio:unset!important;padding:4px 2px!important;border-radius:10px!important;border:1px solid var(--border)!important;background:#fafafa!important;color:#212121!important;cursor:pointer!important;transition:all .2s!important;box-sizing:border-box!important;overflow:visible!important;flex:none!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item.is-preset,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item.is-preset{background:#f3f4f6!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item .cat-icon,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item .cat-icon{font-size:18px!important;line-height:1!important;margin:0 0 2px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item .cat-name,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item .cat-name{font-size:7px!important;color:#212121!important;text-align:center!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:100%!important;line-height:1.1!important;margin:0!important}@media (max-width: 767px){.dialog-expense .expense-category-grid-wrap .expense-category-grid,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-grid{grid-auto-rows:auto!important}.dialog-expense .expense-category-grid-wrap .expense-category-item,.form-dialog.dialog-expense .expense-category-grid-wrap .expense-category-item{height:auto!important;min-height:0!important;max-height:none!important;aspect-ratio:1 / 1!important;width:90%!important;justify-self:center!important;align-self:center!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-grid,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-grid{grid-auto-rows:auto!important;gap:10px!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item{height:auto!important;min-height:0!important;max-height:none!important;aspect-ratio:1 / 1!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item .cat-icon,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item .cat-icon{font-size:16px!important}}.cat-row-preset{color:var(--text-sub)!important}.cat-lock-icon{margin-right:4px;opacity:.7}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item:hover{border-color:#ec4899!important;background:#fdf2f8!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item.active{border-color:#ec4899!important;background:#fff0f5!important;color:#9d174d!important;box-shadow:0 0 0 1px #ec4899!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-item.active .cat-name{color:#9d174d!important}.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item:hover{border-color:#f43f5e!important;background:#fff1f2!important}.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item.active{border-color:#f43f5e!important;background:#fff1f2!important;color:#881337!important;box-shadow:0 0 0 1px #f43f5e!important}.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-item.active .cat-name{color:#881337!important}.form-dialog.dialog-gift-out .gift-category-grid-wrap .gift-category-empty,.form-dialog.dialog-gift-in .gift-category-grid-wrap .gift-category-empty{grid-column:1 / -1!important;padding:24px 16px!important;text-align:center!important;color:var(--text-sub)!important;font-size:14px!important;line-height:1.5!important;background:#f5f5f5!important;border-radius:10px!important;border:1px dashed var(--border)!important;box-sizing:border-box!important}.upload-area{border:2px dashed var(--border);border-radius:8px;padding:6px 12px;text-align:center;cursor:pointer;transition:border-color .2s;position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.upload-area-content{display:flex;align-items:center;justify-content:center;gap:8px;pointer-events:none}.upload-area-camera{width:26px;height:26px;object-fit:contain;flex-shrink:0}.upload-area-text{font-size:12px;color:#888;line-height:1.3}.upload-area-text--hint{color:#e53935}.upload-area:hover{border-color:var(--primary)}.upload-area input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.form-dialog .upload-area .upload-area-camera{mix-blend-mode:multiply}.upload-preview{position:relative;display:inline-block}.upload-preview img{max-width:200px;max-height:150px;border-radius:8px;object-fit:cover}.upload-remove{position:absolute;top:-8px;right:-8px;background:#e53935;color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.summary-table{background:#fff;border-radius:var(--radius);overflow-x:auto;overflow-y:visible;box-shadow:var(--shadow);width:100%;min-width:0}.summary-table .el-table{width:100%!important;min-width:0;table-layout:fixed}.summary-table .el-table .el-table__inner-wrapper{min-width:0}.summary-table .el-table .el-table__body td.el-table__cell .cell,.summary-table .el-table .el-table__footer td.el-table__cell .cell{overflow:visible!important;text-overflow:clip!important;white-space:nowrap!important;padding-left:4px!important;padding-right:4px!important}.page-expense .summary-group .summary-table--period-summary .el-table thead th:first-child .cell,.page-expense .summary-group .summary-table--period-summary .el-table__body td:first-child .cell{padding-left:12px!important;padding-right:10px!important}.page-expense .summary-group .summary-table--period-summary .el-table thead th:last-child .cell,.page-expense .summary-group .summary-table--period-summary .el-table__body td:last-child .cell{padding-left:10px!important;padding-right:12px!important}.page-expense .summary-group .summary-table--period-summary .el-table thead th:not(:first-child):not(:last-child) .cell,.page-expense .summary-group .summary-table--period-summary .el-table__body td:not(:first-child):not(:last-child) .cell{padding-left:10px!important;padding-right:10px!important}.page-expense .summary-group .summary-table--period-summary .el-table thead th:nth-child(1),.page-expense .summary-group .summary-table--period-summary .el-table__body td:nth-child(1){max-width:min(56%,16rem)}.page-expense .summary-group .summary-table--period-summary .el-table thead th:nth-child(2),.page-expense .summary-group .summary-table--period-summary .el-table__body td:nth-child(2){width:102px;max-width:118px}.page-expense .summary-group .summary-table--period-summary .el-table thead th:nth-child(3),.page-expense .summary-group .summary-table--period-summary .el-table__body td:nth-child(3){width:52px;max-width:60px}.page-expense .summary-group .summary-table--period-summary .el-table thead th:nth-child(4),.page-expense .summary-group .summary-table--period-summary .el-table__body td:nth-child(4){width:56px;max-width:64px}.page-expense .summary-group .summary-table--period-summary .el-table thead th.el-table__cell .cell,.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th.el-table__cell .cell{font-size:12px!important;line-height:1.4!important;font-weight:600}.page-expense .summary-group .summary-table--monthly-summary .el-table thead th:nth-child(2) .expense-monthly-summary-th-total{display:inline-block;transform:translate(-1ch)}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:first-child .cell,.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:first-child .cell{padding-left:12px!important;padding-right:10px!important}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:last-child .cell,.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:last-child .cell{padding-left:10px!important;padding-right:12px!important}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:not(:first-child):not(:last-child) .cell,.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:not(:first-child):not(:last-child) .cell{padding-left:10px!important;padding-right:10px!important}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:nth-child(1),.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:nth-child(1){max-width:min(56%,16rem)}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:nth-child(2),.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:nth-child(2){width:102px;max-width:118px}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:nth-child(3),.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:nth-child(3){width:52px;max-width:60px}.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:nth-child(4),.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:nth-child(4){width:56px;max-width:64px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:first-child .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:first-child .cell{padding-left:calc(6px + 1ch)!important;padding-right:2px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(2) .gift-summary-th-dual,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(3) .gift-summary-th-dual{display:inline-block;transform:translate(-1ch)}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:last-child .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:last-child .cell{padding-left:2px!important;padding-right:10px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(2) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(2) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(3) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(3) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(4) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(4) .cell{padding-left:2px!important;padding-right:2px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(1),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(1){max-width:min(34%,11rem)}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(2),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(2),.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(3),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(3){width:72px;max-width:84px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(4),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(4){width:40px;max-width:48px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(5),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(5){width:52px;max-width:58px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th .cell{font-size:14px;font-weight:600;line-height:1.25}.gift-summary-th-dual .gift-summary-hd-short{display:none}.gift-summary-th-dual .gift-summary-hd-long{display:inline}@media (max-width: 767px){.gift-summary-th-dual .gift-summary-hd-long{display:none}.gift-summary-th-dual .gift-summary-hd-short{display:inline}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th.el-table__cell .cell{overflow:visible!important;text-overflow:clip!important;white-space:nowrap!important;line-height:1.2!important;font-size:11px!important;font-weight:600!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(1),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(1){max-width:none;min-width:0;width:auto}.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:first-child .cell{padding-left:calc(4px + 1ch)!important;padding-right:0!important}.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(2) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(3) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(4) .cell{padding-left:1px!important;padding-right:1px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(2) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(3) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(4) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(5) .cell{padding-left:1px!important;padding-right:1px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:first-child .cell{padding-left:calc(4px + 1ch)!important;padding-right:0!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(2),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(2),.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(3),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(3){width:56px;max-width:62px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(4),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(4){width:32px;max-width:36px}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(5) .cell,.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(5) .cell{padding-left:1px!important;padding-right:8px!important}.page-gift .summary-group .summary-table--gift-out-in .el-table thead th:nth-child(5),.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(5){width:46px!important;max-width:52px!important;min-width:44px!important;box-sizing:border-box!important}.page-gift .summary-group .summary-table--gift-out-in .gift-summary-row-action.el-button.is-text,.page-gift .summary-group .summary-table--gift-out-in .gift-summary-row-action.el-button--text{padding:0 1px!important;font-size:11px!important;min-height:auto!important;height:auto!important;margin:0!important;max-width:none;box-sizing:border-box!important;white-space:nowrap!important}.page-gift .summary-group .summary-table--gift-out-in .el-table__body td:nth-child(4) .cell{font-size:11px}.page-gift .summary-group .summary-table--gift-out-in{-webkit-overflow-scrolling:touch}}.page-gift .summary-table--period-summary.summary-table--gift-out-in .el-table__body td:first-child .cell{flex-wrap:nowrap!important;align-items:center!important;white-space:nowrap!important;word-break:normal!important;overflow-wrap:normal!important;overflow:visible!important}.page-gift .summary-table--period-summary .el-table thead th:first-child .cell,.page-gift .summary-table--period-summary .el-table__body td:first-child .cell{padding-left:12px!important;padding-right:10px!important}.page-gift .summary-table--period-summary .el-table__body td:first-child .cell{font-size:12px!important;line-height:1.5!important;display:flex!important;gap:8px!important}.page-gift .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table__body td:first-child .cell{align-items:center!important;flex-wrap:nowrap!important}.page-gift .summary-table--period-summary.summary-table--gift-out-in .el-table__body td:first-child .cell{align-items:center!important;flex-wrap:nowrap!important;gap:4px!important}.page-gift .summary-group .summary-table--period-summary.summary-table--gift-out-in .el-table thead th:first-child .cell,.page-gift .summary-group .summary-table--period-summary:not(.summary-table--gift-out-in) .el-table thead th:first-child .cell{display:flex!important;align-items:center!important;line-height:1.5!important}.page-gift .summary-table--period-summary .cat-table-icon{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:1.35em!important;min-width:1.35em!important;margin-right:0!important;flex-shrink:0!important;font-size:1.2em!important;line-height:1!important;vertical-align:unset!important}.page-gift .summary-table--period-summary:not(.summary-table--gift-out-in) .gift-summary-cat-name{white-space:nowrap!important;flex-shrink:0!important;overflow:visible!important}.page-gift .summary-table--period-summary.summary-table--gift-out-in .gift-summary-cat-name{white-space:nowrap!important;flex-shrink:0!important;min-width:0;overflow:visible!important}.page-gift .summary-table--period-summary .el-table thead th:last-child .cell,.page-gift .summary-table--period-summary .el-table__body td:last-child .cell{padding-left:10px!important;padding-right:12px!important}.page-gift .summary-table--period-summary .el-table thead th:not(:first-child):not(:last-child) .cell,.page-gift .summary-table--period-summary .el-table__body td:not(:first-child):not(:last-child) .cell{padding-left:10px!important;padding-right:10px!important}.page-gift .summary-table--period-summary .el-table thead th:first-child,.page-gift .summary-table--period-summary .el-table__body td:first-child{width:auto;min-width:72px}.summary-amount-cell{white-space:nowrap!important;overflow:visible!important;display:inline-block;font-weight:600;line-height:1.3;max-width:100%}.page-gift .summary-group .summary-table--gift-out-in .summary-amount-cell{max-width:none!important}.summary-table .el-table__footer-wrapper .el-table__footer td .cell{white-space:nowrap!important;overflow:visible!important;text-overflow:clip!important;font-weight:600;font-size:12px;padding-left:4px!important;padding-right:4px!important}@media (max-width: 360px){.summary-amount-cell{font-size:10px}}@media (min-width: 768px){.summary-amount-cell{font-size:14px}}.summary-table .cat-table-icon{display:inline-block;margin-right:8px;font-size:1.2em;line-height:1;vertical-align:middle}.pagination-wrap{display:flex;justify-content:center;margin-top:16px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-sub)}.empty-state .icon{font-size:60px;margin-bottom:12px}.loading-wrap{display:flex;justify-content:center;padding:40px}@media (max-width: 480px){.summary-cards{grid-template-columns:repeat(3,1fr);gap:8px}.summary-cards.summary-cards-2col{grid-template-columns:1fr 1fr;gap:8px}.summary-card-col{gap:8px}.summary-card.summary-card-dual{padding:12px}.dual-label{font-size:13px}.dual-value{font-size:20px}.summary-card.summary-card-amount{padding:10px 8px}.summary-card .label{font-size:12px}.summary-card .value{font-size:18px}.summary-cards.summary-cards-row{gap:6px}.summary-card.summary-card-compact{padding:7px 4px}.summary-card.summary-card-compact .label{font-size:11px}.summary-card.summary-card-compact .value{font-size:15px}.summary-stats-bar{gap:6px}.summary-stats-bar .stats-count-box{padding:4px 6px}.stats-count-item .label{font-size:10px}.stats-count-item .value{font-size:11px}.page-content{padding:6px 10px 72px}}.el-button--primary{background:var(--primary)!important;border-color:var(--primary)!important}.el-button--primary:hover{background:var(--primary-dark)!important;border-color:var(--primary-dark)!important}.el-tabs__item.is-active{color:var(--primary)!important}.el-tabs__active-bar{background-color:var(--primary)!important}.el-tabs__header,.el-tabs__nav-wrap,.el-tabs__nav-scroll{width:100%}.el-tabs__nav{display:flex!important;width:100%!important;justify-content:space-between}.el-tabs__item{flex:1!important;text-align:center!important;padding:0 6px!important}@media (max-width: 480px){.el-tabs__header{margin-bottom:8px}.el-tabs__item{font-size:12px!important;padding:0 4px!important}}.login-page{min-height:100vh;background:linear-gradient(135deg,#1b5e20,#2e7d32,#388e3c,#43a047,#66bb6a,#a5d6a7);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,.03) 20px,rgba(255,255,255,.03) 40px)}.login-page:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(255,255,255,.08) 0%,transparent 60%);animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:1}}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:48px 40px;width:380px;max-width:calc(100vw - 40px);box-shadow:0 20px 60px #0003,0 0 0 1px #ffffff4d;position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:32px}.login-logo .icon{font-size:56px;display:block;margin-bottom:12px}.login-logo h1{font-size:22px;font-weight:800;color:var(--primary-dark);letter-spacing:2px}.login-logo p{font-size:13px;color:var(--text-sub);margin-top:4px}.login-btn{width:100%;height:48px;font-size:16px;font-weight:600;border-radius:12px;background:linear-gradient(135deg,#2e7d32,#4caf50)!important;border:none!important;letter-spacing:2px;margin-top:8px}.login-card .el-input__wrapper{overflow:hidden;width:100%;box-sizing:border-box}.login-card .el-input{width:100%}.login-card .el-form-item__content{overflow:hidden}.login-card .el-form-item:first-child .el-input__prefix .el-icon{color:#409eff!important;font-size:18px!important}.login-card .el-form-item:nth-child(2) .el-input__prefix .el-icon{color:#f56c6c!important;font-size:18px!important}.login-card .el-input__suffix .el-icon{color:#f56c6c!important}.login-card .el-input__suffix:hover .el-icon{color:#e6a23c!important}.admin-page{padding:20px;max-width:1000px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{font-size:20px;font-weight:700;color:var(--text-main)}.tag-expense{background:#fff3e0;color:#e65100}.tag-gift-out{background:#fce4ec;color:#c62828}.tag-gift-in{background:#e8f5e9;color:#1b5e20}.tag-user{background:#e3f2fd;color:#0d47a1}.tag-system{background:#f3e5f5;color:#4a148c}.dialog-gift-out .el-dialog__header{background:linear-gradient(135deg,#e1bee7,#ce93d8);border-radius:8px 8px 0 0;padding:16px 20px;margin:0}.dialog-gift-out .el-dialog__title{color:#4a148c;font-weight:600}.dialog-gift-out .el-dialog__body{background:#f3e5f5}.dialog-gift-out .el-dialog__footer{background:#f3e5f5;border-radius:0 0 8px 8px}.el-overlay-dialog .cat-dialog.el-dialog,.cat-dialog.el-dialog{border-radius:14px!important;overflow:hidden!important;width:100%!important;max-width:420px!important;max-height:calc(100vh - 60px)!important;margin:var(--el-dialog-margin-top, 15vh) auto 50px!important;padding:0!important;display:flex!important;flex-direction:column!important}@media (max-width: 768px){.el-overlay-dialog .cat-dialog.el-dialog,.cat-dialog.el-dialog{width:calc(100vw - 10px)!important;max-width:calc(100vw - 10px)!important;margin-left:auto!important;margin-right:auto!important}}.cat-dialog.el-dialog .el-dialog__header{padding:14px 16px 10px!important}.cat-dialog.el-dialog .el-dialog__body{padding:10px 16px 12px!important;flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important}.cat-dialog.el-dialog .el-dialog__footer{padding:12px 16px 20px!important;border-top:1px solid #e4e7ed!important}.cat-dialog.el-dialog .el-dialog__footer .el-button{pointer-events:auto!important;flex:1!important;max-width:none!important}.cat-dialog.el-dialog .el-dialog__footer>div,.cat-dialog.el-dialog .el-dialog__footer .cat-dialog-footer{width:100%;display:flex;justify-content:center;align-items:center;gap:12px}.cat-dialog.el-dialog .el-form{width:100%;margin:0}.cat-dialog.el-dialog .el-form-item__content{flex:1;min-width:0}.cat-dialog.el-dialog .icon-picker-wrap{width:100%;min-height:0;flex-shrink:1}.logout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#00000073;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.logout-dialog{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000002e;padding:32px 28px 24px;width:100%;max-width:320px;text-align:center;box-sizing:border-box}.logout-dialog-icon{font-size:36px;margin-bottom:10px;line-height:1}.logout-dialog-title{font-size:17px;font-weight:700;color:#222;margin-bottom:8px}.logout-dialog-msg{font-size:14px;color:#666;margin-bottom:28px;line-height:1.5}.logout-dialog-btns{display:flex;gap:12px;justify-content:center}.logout-btn-cancel,.logout-btn-confirm{flex:1;max-width:120px;height:42px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.logout-btn-cancel{background:#f0f0f0;color:#444}.logout-btn-confirm{background:#e53935;color:#fff}.logout-btn-cancel:active,.logout-btn-confirm:active{opacity:.8;transform:scale(.97)}.logout-btn-confirm:disabled{opacity:.6;cursor:not-allowed}.logout-fade-enter-active,.logout-fade-leave-active{transition:opacity .2s ease}.logout-fade-enter-active .logout-dialog,.logout-fade-leave-active .logout-dialog{transition:transform .2s ease,opacity .2s ease}.logout-fade-enter-from,.logout-fade-leave-to{opacity:0}.logout-fade-enter-from .logout-dialog{transform:scale(.92) translateY(10px)}.logout-fade-leave-to .logout-dialog{transform:scale(.92) translateY(10px);opacity:0}.el-overlay.is-message-box{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;z-index:9999!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0 16px!important;background:#0009!important;backdrop-filter:blur(3px)!important;-webkit-backdrop-filter:blur(3px)!important}.el-message-box__wrapper{position:static!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:auto!important;top:auto!important;left:auto!important;transform:none!important}.el-message-box{position:relative!important;top:auto!important;left:auto!important;transform:none!important;margin:0 auto!important;width:100%!important;max-width:300px!important;border-radius:20px!important;overflow:visible!important;background:#fff!important;box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a,0 0 0 1px #0000000a!important;padding-bottom:0!important}.el-message-box__header{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:20px 20px 12px!important;border-bottom:1px solid #f0f0f0!important}.el-message-box__title{font-size:17px!important;font-weight:700!important;color:#1a1a1a!important;line-height:1.4!important;flex:1!important;text-align:center!important}.el-message-box__headerbtn{position:static!important;top:auto!important;right:auto!important;width:28px!important;height:28px!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:50%!important;background:#f5f5f5!important;border:none!important;cursor:pointer!important;flex-shrink:0!important;transition:background .2s!important}.el-message-box__headerbtn:hover{background:#ebebeb!important}.el-message-box__headerbtn .el-message-box__close{font-size:14px!important;color:#888!important}.el-message-box__content{padding:20px 20px 4px!important;display:flex!important;align-items:flex-start!important;gap:10px!important}.el-message-box__status.el-icon{display:none!important}.el-message-box__message{flex:1!important;text-align:center!important}.el-message-box__message p{margin:0!important;font-size:15px!important;color:#444!important;line-height:1.65!important}.el-message-box__btns{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:9px!important;padding:18px 16px 20px!important;margin-top:0!important}.el-message-box__btns .el-button{flex:1 1 0!important;min-width:100px!important;max-width:140px!important;height:44px!important;padding:0 24px!important;border-radius:12px!important;font-size:15px!important;font-weight:500!important;letter-spacing:.3px!important;transition:all .18s ease!important;cursor:pointer!important;margin:0!important}.el-message-box__btns .el-button:active{transform:scale(.97)!important;opacity:.9!important}.el-message-box__btns .el-button--default{background:#f5f5f5!important;border:1.5px solid #e0e0e0!important;color:#555!important;font-weight:400!important}.el-message-box__btns .el-button--default:hover{background:#ebebeb!important;border-color:#c8c8c8!important;color:#222!important}.el-message-box__btns .el-button--primary,.el-message-box__btns .el-button--danger{background:#e53935!important;border:none!important;color:#fff!important;font-weight:700!important;box-shadow:0 4px 14px #e5393561!important}.el-message-box__btns .el-button--primary:hover,.el-message-box__btns .el-button--danger:hover{background:#c62828!important;box-shadow:0 6px 18px #c6282873!important}@media (max-width: 480px){.record-row1{flex-wrap:nowrap;gap:4px}.record-row1-left{flex:1 1 auto;min-width:0;overflow:hidden;white-space:nowrap;flex-wrap:nowrap}.record-datetime,.record-operator{font-size:9.5px;white-space:nowrap;flex-shrink:0;overflow:visible}.record-amount{max-width:48%;flex:0 0 auto;overflow:visible}}.cat-dialog .el-dialog__body{padding:10px 16px 12px}.cat-dialog .el-form,.cat-dialog .icon-picker-wrap{width:100%;margin:0}.cat-dialog .el-form-item{margin-bottom:0}.cat-dialog .el-form-item__content{flex:1;min-width:0}.cat-dialog .el-form-item__label{font-size:13px;color:#606266;padding-bottom:6px}.cat-dialog .icon-picker-wrap{width:100%}.cat-dialog .el-dialog__footer{padding:12px 16px 20px}.cat-dialog-footer{display:flex;justify-content:center;align-items:center;gap:12px;width:100%}.cat-dialog-footer .el-button{flex:1;max-width:none}
