*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #0070BA;--primary-dk: #005EA6;--primary-lt: #009CDE;--navy: #003087;--success: #00A651;--warning: #E6A817;--error: #D0021B;--bg: #F5F7FA;--surface: #FFFFFF;--text-1: #2C2E2F;--text-2: #6A7380;--text-3: #B5BBC2;--text: #2C2E2F;--border: #DDE2E5;--nav-bg: #FFFFFF;--shadow-sm: 0 1px 6px rgba(0,56,135,.08);--shadow-md: 0 4px 20px rgba(0,56,135,.13);--shadow-blue:0 4px 16px rgba(0,112,186,.3);--radius: 10px;--radius-sm: 8px;--radius-btn: 24px;--nav-h: 64px;--safe-b: env(safe-area-inset-bottom, 0px)}html,body{height:100%}body{font-family:Sarabun,-apple-system,sans-serif;font-size:15px;background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}#root{height:100%}.app-layout{display:flex;flex-direction:column;height:100%;min-height:100dvh}.app-main{flex:1;overflow-y:auto;padding-bottom:calc(var(--nav-h) + var(--safe-b) + 8px)}.page{padding:0 0 24px}.page-header{background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);color:#fff;padding:22px 20px 20px;padding-top:calc(22px + env(safe-area-inset-top,0px))}.page-title{font-size:22px;font-weight:700;letter-spacing:-.3px}.page-subtitle{font-size:13px;color:#ffffffa6;margin-top:3px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100;box-shadow:0 -2px 16px #00388714}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 18px;border:none;background:none;cursor:pointer;color:var(--text-3);text-decoration:none;font-family:inherit;font-size:11px;-webkit-tap-highlight-color:transparent;transition:color .15s;position:relative}.nav-item.active,.nav-item:hover{color:var(--primary)}.nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--primary);border-radius:0 0 4px 4px}.nav-logout{color:var(--text-3)}.nav-icon{font-size:22px}.nav-label{font-size:10px;font-weight:600;letter-spacing:.2px}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(160deg,var(--navy) 0%,#013B8A 55%,var(--primary) 100%)}.login-card{width:100%;max-width:380px;background:var(--surface);border-radius:16px;padding:36px 28px 32px;box-shadow:0 20px 60px #00000059}.login-logo{text-align:center;margin-bottom:28px}.login-icon{font-size:52px}.login-title{font-size:26px;font-weight:800;color:var(--navy);margin-top:10px;letter-spacing:-.5px}.login-subtitle{font-size:14px;color:var(--text-2);margin-top:4px}.login-form{display:flex;flex-direction:column;gap:16px}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:var(--text-2)}.field-input{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:15px;color:var(--text-1);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0070ba1f}select.field-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-btn);font-family:inherit;font-size:15px;font-weight:700;letter-spacing:.2px;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-blue)}.btn-primary:hover{background:var(--primary-dk)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn-block{width:100%}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;background:transparent;color:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-btn);font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.btn-secondary:hover{background:#0070ba0d}.btn-sm{padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-btn);font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-blue)}.btn-delete{padding:7px 12px;background:#fff0f0;color:var(--error);border:none;border-radius:20px;font-size:14px;cursor:pointer;font-weight:600}.btn-ghost{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-2);padding:0 4px;line-height:1}.btn-link{background:none;border:none;color:var(--primary);font-size:12px;padding:2px 0;cursor:pointer;font-weight:700;font-family:inherit}.btn-retry{padding:5px 14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-btn);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}.input-hidden{display:none}.upload-page{min-height:100%}.upload-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px}.btn-upload-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 16px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:14px;font-weight:700;color:var(--primary);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent;transition:border-color .15s,box-shadow .15s,transform .1s}.btn-upload-action:hover{border-color:var(--primary);box-shadow:var(--shadow-blue)}.btn-upload-action:active{transform:scale(.97)}.btn-upload-action:disabled{opacity:.45;cursor:default}.btn-upload-action .icon{font-size:32px}.upload-empty{display:flex;flex-direction:column;align-items:center;padding:56px 32px 32px;text-align:center}.upload-empty-icon{font-size:58px;margin-bottom:16px;opacity:.35}.upload-empty-hint{font-size:14px;line-height:1.75;color:var(--text-2)}.feed-label{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);padding:4px 16px 10px}.slip-feed{display:flex;flex-direction:column;gap:10px;padding:0 16px 8px}.feed-card{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);overflow:hidden;transition:border-color .2s,box-shadow .2s}.feed-card--processing{border-color:var(--primary-lt);box-shadow:0 0 0 1px var(--primary-lt),var(--shadow-sm)}.feed-card--done{border-color:var(--success);box-shadow:0 0 0 1px var(--success),var(--shadow-sm)}.feed-card--error{border-color:var(--error);box-shadow:0 0 0 1px var(--error),var(--shadow-sm)}.feed-card-main{display:flex;align-items:flex-start;gap:12px;padding:14px}.feed-thumb-wrap{position:relative;flex-shrink:0}.feed-thumb{width:68px;height:68px;border-radius:8px;object-fit:cover;display:block;border:1px solid var(--border)}.feed-thumb-ph{width:68px;height:68px;border-radius:8px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.feed-thumb-badge{position:absolute;bottom:-6px;right:-6px;width:22px;height:22px;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:800;border:2px solid var(--surface)}.feed-thumb-badge--done{background:var(--success);color:#fff}.feed-thumb-badge--error{background:var(--error);color:#fff}.feed-body{flex:1;min-width:0;padding-top:2px}.feed-num{font-size:10px;font-weight:700;color:var(--text-3);letter-spacing:1px;text-transform:uppercase;margin-bottom:5px}.feed-status-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.feed-amount{font-size:22px;font-weight:800;color:var(--navy);letter-spacing:-.5px;margin-top:2px}.feed-name{font-size:13px;color:var(--text-2);margin-top:2px}.feed-compress{font-size:11px;color:var(--text-3);margin-top:4px}.feed-compress-saved{color:var(--success);font-weight:700}.feed-error-msg{font-size:12px;color:var(--error);margin-top:4px;line-height:1.4;font-weight:500}.feed-processing-txt{font-size:13px;color:var(--primary);font-weight:600}.feed-action{display:flex;flex-direction:column;gap:6px;align-items:flex-end;flex-shrink:0}.feed-remove{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);background:none;cursor:pointer;font-size:12px;color:var(--text-2);display:flex;align-items:center;justify-content:center}.feed-toggle{display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 14px;width:100%;border:none;border-top:1px solid var(--border);background:var(--bg);font-family:inherit;font-size:12px;font-weight:700;color:var(--primary);cursor:pointer;letter-spacing:.2px}.feed-detail{border-top:1px solid var(--border);padding:14px;background:var(--bg);animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.data-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.data-row:last-child{border-bottom:none}.data-label{font-size:12px;color:var(--text-2);flex-shrink:0;font-weight:500}.data-value{font-size:13px;text-align:right;word-break:break-all;font-weight:600;color:var(--text-1)}.data-value.mono{font-family:monospace;font-size:12px;font-weight:400}.data-value.highlight{font-size:18px;font-weight:800;color:var(--navy)}.divider{border:none;border-top:1px solid var(--border);margin:4px 0}.badge{display:inline-block;padding:3px 12px;border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.2px}.badge-normal{background:#e6f4ea;color:#1b6a35}.badge-warning{background:#fef3c7;color:#92400e}.badge-error{background:#fee8e8;color:#9b1c1c}.alert-banner{display:flex;align-items:center;gap:10px;padding:13px 16px;font-size:13px;font-weight:500}.alert-warning{background:#fffbeb;border-bottom:2px solid var(--warning);color:#7a5200}.filter-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-bar-wrap{flex-wrap:wrap}.filter-input{flex:1;min-width:100px;padding:9px 12px;border:1.5px solid var(--border);border-radius:20px;font-family:inherit;font-size:13px;outline:none;background:var(--bg);color:var(--text-1)}.filter-input:focus{border-color:var(--primary);background:#fff}.filter-sep{color:var(--text-3);font-size:13px}.transaction-list{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.list-count{font-size:12px;color:var(--text-3);padding-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tx-card{background:var(--surface);border-radius:var(--radius);padding:16px;border:1.5px solid var(--border);box-shadow:var(--shadow-sm)}.tx-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.tx-date{font-size:12px;color:var(--text-2);font-weight:500}.tx-amount{font-size:24px;font-weight:800;color:var(--navy);margin-bottom:10px;letter-spacing:-.5px}.tx-detail{display:flex;gap:6px;font-size:13px;margin-bottom:3px}.tx-label{color:var(--text-2);flex-shrink:0;font-weight:500}.tx-id{font-family:monospace;font-size:11px;color:var(--text-3);margin-top:8px}.no-data{font-size:14px;color:var(--text-3);font-weight:500}.tx-by{font-size:12px;color:var(--text-3)}.tab-bar{display:flex;border-bottom:2px solid var(--border);background:var(--surface);overflow-x:auto}.tab-btn{padding:14px 18px;border:none;background:none;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;color:var(--text-2);white-space:nowrap;border-bottom:3px solid transparent;margin-bottom:-2px;-webkit-tap-highlight-color:transparent;transition:color .15s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.summary-bar{display:flex;justify-content:space-between;padding:10px 16px;font-size:13px;color:var(--text-2);background:var(--surface);border-bottom:1px solid var(--border)}.summary-amount{font-weight:700;color:var(--navy)}.admin-tx-list{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.admin-tx-card{background:var(--surface);border-radius:var(--radius);padding:14px;border:1.5px solid var(--border);box-shadow:var(--shadow-sm)}.admin-tx-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.admin-tx-right{display:flex;align-items:center;gap:8px}.user-list{display:flex;flex-direction:column;gap:10px}.user-card-wrap{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.user-card-wrap.user-inactive{opacity:.45}.user-card{padding:14px 16px;display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.user-name{font-size:15px;font-weight:700;color:var(--text-1)}.user-meta{font-size:12px;color:var(--text-3);margin-top:2px}.user-group{display:inline-block;margin-top:5px;padding:3px 12px;background:#eaf3ff;color:var(--navy);border-radius:99px;font-size:11px;font-weight:700}.user-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.btn-edit{background:var(--bg);color:var(--text-1);border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.edit-panel{border-top:1px solid var(--border);background:var(--bg);padding:16px;display:flex;flex-direction:column;gap:12px}.edit-panel-actions{display:flex;gap:10px;margin-top:4px}.edit-panel-actions .btn-primary,.edit-panel-actions .btn-secondary{flex:1;padding:11px}.add-user-form{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:14px}.change-pin-form{display:flex;flex-direction:column;gap:14px;padding:16px;max-width:400px}.error-banner{background:#fee8e8;color:#9b1c1c;border-radius:var(--radius-sm);padding:11px 16px;font-size:14px;font-weight:600;margin:4px 0;border-left:4px solid var(--error)}.success-banner{background:#e6f4ea;color:#1b5e30;border-radius:var(--radius-sm);padding:11px 16px;font-size:14px;font-weight:600;margin-bottom:12px;border-left:4px solid var(--success)}.audit-list{display:flex;flex-direction:column;gap:8px}.audit-entry{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);padding:12px 14px}.audit-icon{font-size:20px;flex-shrink:0}.audit-body{flex:1;min-width:0}.audit-label{font-weight:700;font-size:13px;color:var(--text-1)}.audit-detail{font-size:12px;color:var(--text-2);margin-top:2px;word-break:break-all}.audit-time{font-size:12px;color:var(--text-3);flex-shrink:0;font-weight:600}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.center-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;color:var(--text-2)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-2)}.empty-icon{font-size:52px;margin-bottom:14px;opacity:.3}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner-dark{display:inline-block;width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.status-normal{background:#e6f4ea;color:#1b6a35}.status-warning{background:#fef3c7;color:#92400e}.status-error{background:#fee8e8;color:#9b1c1c}.warnings-box{background:#fffbeb;border:1px solid var(--warning);border-radius:var(--radius-sm);padding:12px;margin-top:8px}.warning-item{font-size:13px;color:#7a5200;line-height:1.5}.result-card{background:var(--surface);border-radius:var(--radius);padding:16px;border:1.5px solid var(--border)}.result-card-title{font-size:11px;font-weight:700;color:var(--text-3);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--error);color:#fff;border-radius:99px;font-size:11px;font-weight:800;margin-left:5px;line-height:1}.status-filter-bar{display:flex;gap:6px;padding:10px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--bg);border-bottom:1px solid var(--border)}.status-filter-btn{padding:6px 14px;border:1.5px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);font-family:inherit;font-size:12px;font-weight:600;color:var(--text-2);cursor:pointer;white-space:nowrap;transition:all .15s}.status-filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.status-filter-btn.pending.active{background:#e6a817;border-color:#e6a817;color:#fff}.status-filter-btn.pending{border-color:#e6a817;color:#92400e}.admin-tx-card--pending{border-left:4px solid #E6A817;background:#fffdf0}.tx-approve-bar{display:flex;gap:8px;padding-top:10px;margin-top:8px;border-top:1px solid var(--border)}.btn-approve{flex:1;padding:9px;background:var(--success);color:#fff;border:none;border-radius:var(--radius-btn);font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #00a65140}.btn-approve:disabled{opacity:.55;cursor:not-allowed}.btn-reject{flex:1;padding:9px;background:transparent;color:var(--error);border:2px solid var(--error);border-radius:var(--radius-btn);font-family:inherit;font-size:13px;font-weight:700;cursor:pointer}.btn-reject:disabled{opacity:.55;cursor:not-allowed}.tx-group-tag{display:inline-block;margin-left:6px;padding:1px 8px;background:#eaf3ff;color:var(--navy);border-radius:99px;font-size:11px;font-weight:600}.breakdown-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.breakdown-title{font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-2);padding:14px 16px 10px;border-bottom:1px solid var(--border)}.sub-pct{font-size:11px;color:var(--text-3);font-weight:600;text-align:right;margin-top:3px}.summary-tab{padding:16px;display:flex;flex-direction:column;gap:16px}.period-bar{display:flex;align-items:center;gap:6px}.period-btn{flex:1;padding:9px 0;border:1.5px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);font-family:inherit;font-size:13px;font-weight:700;color:var(--text-2);cursor:pointer;transition:all .15s}.period-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-blue)}.period-view-toggle{display:flex;gap:2px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-btn);padding:3px;margin-left:4px}.view-btn{padding:5px 12px;border:none;border-radius:20px;background:none;font-family:inherit;font-size:13px;font-weight:700;color:var(--text-2);cursor:pointer;transition:all .15s}.view-btn.active{background:var(--primary);color:#fff}.stat-cards{display:grid;grid-template-columns:1fr;gap:10px}@media (min-width: 360px){.stat-cards{grid-template-columns:1fr 1fr}.stat-card:first-child{grid-column:1 / -1}}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.stat-card--accent{background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);border-color:transparent;color:#fff}.stat-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}.stat-card--accent .stat-label{color:#ffffffa6}.stat-value{font-size:22px;font-weight:800;color:var(--navy);letter-spacing:-.5px;line-height:1.1}.stat-card--accent .stat-value{color:#fff;font-size:26px}.stat-sub{font-size:12px;color:var(--text-3);margin-top:4px;font-weight:500}.stat-card--accent .stat-sub{color:#fff9}.chart-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.chart-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 10px}.chart-card-title{font-size:13px;font-weight:700;color:var(--text-1)}.chart-card-hint{font-size:11px;color:var(--text-3)}.chart-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 8px 12px}.chart-scroll::-webkit-scrollbar{height:4px}.chart-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.day-detail{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.day-detail-head{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);color:#fff}.day-detail-datestr{font-size:16px;font-weight:700}.day-detail-sub{font-size:12px;color:#ffffffa6;margin-top:2px}.day-detail-amount{font-size:24px;font-weight:800;letter-spacing:-.5px}.day-detail-empty{padding:28px;text-align:center;color:var(--text-3);font-size:14px}.day-status-row{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border)}.day-detail-section-title{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);padding:12px 16px 6px}.sub-row{padding:8px 16px}.sub-row:not(:last-child){border-bottom:1px solid var(--border)}.sub-row-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.sub-name{font-size:13px;font-weight:600;color:var(--text-1)}.sub-stats{font-size:12px;color:var(--text-2)}.sub-bar-bg{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}.sub-bar-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--primary-lt));border-radius:3px;transition:width .4s ease;min-width:4px}.nav-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.nav-badge{position:absolute;top:-5px;right:-8px;min-width:18px;height:18px;padding:0 4px;background:var(--error);color:#fff;font-size:10px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.pending-pill{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 10px);left:50%;transform:translate(-50%);z-index:90;display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--navy);color:#fff;font-size:13px;font-weight:600;border:none;border-radius:24px;box-shadow:0 4px 20px #00308766;cursor:pointer;white-space:nowrap;animation:pill-pop .25s ease}.pending-pill:hover{background:var(--primary-dk)}.pending-pill-dot{width:8px;height:8px;background:#fc0;border-radius:50%;animation:blink 1.4s infinite;flex-shrink:0}.pending-pill-arrow{font-size:14px}@keyframes pill-pop{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.review-page{min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);padding-bottom:calc(var(--nav-h) + var(--safe-b) + 8px)}.review-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);color:#fff}.review-back{background:none;border:none;color:#fff;font-size:14px;font-weight:600;cursor:pointer;padding:4px 0}.review-title{font-size:16px;font-weight:700}.review-bulk{background:#fff3;border:1px solid rgba(255,255,255,.4);color:#fff;font-size:12px;font-weight:600;border-radius:16px;padding:5px 12px;cursor:pointer}.review-bulk:disabled{opacity:.5}.review-loading{flex:1;display:flex;align-items:center;justify-content:center}.review-progress{padding:12px 16px 4px;display:flex;flex-direction:column;align-items:center;gap:8px}.review-progress-text{font-size:12px;color:var(--text-2);font-weight:600}.review-dots{display:flex;gap:6px;align-items:center}.review-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s,transform .2s}.review-dot.done{background:var(--success)}.review-dot.active{background:var(--primary);transform:scale(1.3)}.review-dots-more{font-size:11px;color:var(--text-3);margin-left:2px}.review-hint{display:flex;justify-content:space-between;padding:10px 24px 0;font-size:12px;font-weight:700;letter-spacing:.3px}.hint-reject{color:var(--error)}.hint-approve{color:var(--success)}.review-stack{position:relative;flex:1;display:flex;align-items:flex-start;justify-content:center;padding:12px 16px 16px;min-height:400px}.review-card{position:absolute;width:calc(100% - 32px);max-width:420px;background:var(--surface);border-radius:16px;box-shadow:var(--shadow-md);overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:pan-y;transition:box-shadow .2s}.review-card-ghost{pointer-events:none;background:var(--surface);border-radius:16px;min-height:220px}.review-card-active{cursor:grab;transition:box-shadow .2s;will-change:transform}.review-card-active:active{cursor:grabbing}.review-card-active.swiping-right{box-shadow:0 8px 32px #00a6514d}.review-card-active.swiping-left{box-shadow:0 8px 32px #d0021b4d}.swipe-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;letter-spacing:2px;border-radius:16px;pointer-events:none}.swipe-approve{background:#00a6512e;color:var(--success);border:3px solid var(--success)}.swipe-reject{background:#d0021b21;color:var(--error);border:3px solid var(--error)}.review-card-head{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 18px 12px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);color:#fff}.review-card-name{font-size:17px;font-weight:700}.review-card-date{font-size:12px;color:#ffffffb3;margin-top:3px}.review-card-amount{font-size:24px;font-weight:800;letter-spacing:-.5px}.review-card-body{padding:12px 0}.review-card-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 18px;border-bottom:1px solid var(--bg)}.review-card-label{font-size:12px;color:var(--text-2)}.review-card-val{font-size:13px;font-weight:600;color:var(--text-1);text-align:right;max-width:60%}.review-card-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 16px 18px}.review-btn{padding:13px;border-radius:var(--radius-btn);font-size:15px;font-weight:700;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.review-btn:active{transform:scale(.97)}.review-btn:disabled{opacity:.5;cursor:not-allowed}.review-btn-approve{background:var(--success);color:#fff}.review-btn-reject{background:#fff;color:var(--error);border:2px solid var(--error)}.review-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 24px;text-align:center}.review-done-icon{font-size:56px}.review-done-title{font-size:20px;font-weight:700;color:var(--text-1)}.review-done-sub{font-size:14px;color:var(--text-2)}.review-done-btn{width:100%;max-width:280px}.review-toast{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 70px);left:50%;transform:translate(-50%);z-index:200;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:700;white-space:nowrap;animation:pill-pop .2s ease;pointer-events:none}.review-toast-ok{background:var(--success);color:#fff}.review-toast-err{background:var(--error);color:#fff}@media (min-width: 600px){.app-main{max-width:480px;margin:0 auto}.bottom-nav{max-width:480px;left:50%;transform:translate(-50%);border-radius:12px 12px 0 0}.page-header{border-radius:0}}.date-preset-bar{display:flex;gap:6px;padding:10px 16px 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.date-preset-bar::-webkit-scrollbar{display:none}.date-preset-btn{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.date-preset-btn:hover{border-color:var(--primary);color:var(--primary)}.date-preset-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #0070ba4d}.custom-date-row{display:flex;align-items:center;gap:6px;padding:8px 16px 0;flex-wrap:wrap}.search-bar{display:flex;align-items:center;gap:8px;margin:10px 16px 0;padding:0 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);transition:border-color .15s}.search-bar:focus-within{border-color:var(--primary)}.search-icon{font-size:14px;flex-shrink:0}.search-input{flex:1;border:none;outline:none;background:transparent;padding:10px 0;font-size:14px;color:var(--text-1)}.search-clear{background:none;border:none;color:var(--text-3);font-size:13px;cursor:pointer;padding:4px;flex-shrink:0}.filter-toolbar{display:flex;align-items:center;gap:6px;padding:10px 16px 0;flex-wrap:wrap}.filter-toggle-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.filter-toggle-btn.open,.filter-toggle-btn.has-filter{border-color:var(--primary);color:var(--primary);background:#eaf4fb}.filter-toggle-arrow{font-size:10px}.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:#eaf4fb;border:1.5px solid var(--primary-lt);color:var(--primary-dk);border-radius:16px;font-size:12px;font-weight:600;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.filter-chip button{background:none;border:none;color:var(--primary-dk);cursor:pointer;font-size:11px;padding:0;line-height:1;flex-shrink:0}.filter-drawer{margin:8px 16px 0;padding:14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px}.filter-search-row{display:flex;align-items:center;gap:8px;padding:0 10px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm)}.filter-search-row:focus-within{border-color:var(--primary)}.filter-search-row .search-input{padding:8px 0}.filter-drawer-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px}.filter-drawer-row{display:flex;flex-direction:column;gap:4px}.filter-drawer-label{font-size:11px;font-weight:700;color:var(--text-2);letter-spacing:.4px;text-transform:uppercase}.filter-clear-btn{align-self:flex-start}.tx-dest-row{display:flex;align-items:center;gap:6px;padding:4px 0 2px}.tx-dest-label{font-size:11px;color:var(--text-3);font-weight:600}.tx-dest-chip{font-size:12px;font-weight:600;color:var(--primary-dk);background:#eaf4fb;border:1px solid var(--primary-lt);border-radius:10px;padding:2px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.admin-tx-who{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;padding-right:8px}.tx-submitter{font-size:14px;font-weight:700;color:var(--text-1)}.tx-group-chip{display:inline-block;font-size:11px;font-weight:600;color:var(--primary-dk);background:#eaf4fb;border:1px solid var(--primary-lt);border-radius:8px;padding:1px 7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.list-summary-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px 4px}.list-count{font-size:13px;color:var(--text-2)}.list-total{font-size:15px;font-weight:700;color:var(--primary-dk)}.pagination-bar{display:flex;justify-content:center;align-items:center;gap:4px;padding:16px 16px 24px;flex-wrap:wrap}.page-btn{min-width:36px;height:36px;padding:0 8px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #0070ba4d}.page-btn:disabled{opacity:.35;cursor:not-allowed}.tx-reason-bar{display:flex;align-items:flex-start;gap:6px;padding:7px 10px;background:#fff8e1;border:1px solid #F9A825;border-radius:var(--radius-sm);margin:6px 0}.tx-reason-icon{font-size:13px;flex-shrink:0;line-height:1.4}.tx-reason-text{font-size:12px;color:#5d4037;line-height:1.4;font-weight:500}.review-reason-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 16px;background:#fff3e0;border-bottom:2px solid #FF9800}.review-reason-icon{font-size:16px;flex-shrink:0}.review-reason-text{font-size:13px;color:#4e342e;font-weight:600;line-height:1.4}.tx-group-inline{color:var(--primary-dk);font-weight:600}
