:root{--primary:#002147;--primary-l:#e8ecf2;--primary-d:#001830;--gold:#c5a059;--warn:#f59e0b;--danger:#ef4444;--info:#3b82f6;--text:#1f2937;--text2:#6b7280;--border:#e5e7eb;--bg:#f5f7fa;--surface:#fff;--success:#10b981;--tab-h:56px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--app-min-height:100vh}@supports (height:100dvh){:root{--app-min-height:100dvh}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;height:100%;overflow-x:clip}body{width:100%;max-width:100%;min-height:100%;min-height:var(--app-min-height);background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}#app{width:100%;max-width:100%;min-height:100%;min-height:var(--app-min-height);overflow-x:clip}@supports (-webkit-touch-callout:none){html{height:-webkit-fill-available}body,#app{min-height:-webkit-fill-available;min-height:var(--app-min-height)}}html,body{overflow-x:clip}body::-webkit-scrollbar{width:0;height:0}.app-viewport::-webkit-scrollbar{width:0;height:0}.page-scroll::-webkit-scrollbar{width:0;height:0}body,.app-viewport,.page-scroll{scrollbar-width:none}.app-viewport{width:100%;max-width:430px;min-height:var(--app-min-height);background:var(--bg);margin:0 auto;position:relative;overflow-x:hidden;box-shadow:0 0 40px #00214714}@media (width<=430px){.app-viewport{box-shadow:none}}.page-scroll{padding:12px 14px calc(20px + var(--safe-bottom));-webkit-overflow-scrolling:touch;overflow-y:auto}.layout-default .page-scroll,.has-tab .page-scroll{padding-bottom:calc(var(--tab-h) + 20px + var(--safe-bottom))}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin-bottom:12px;padding:16px;box-shadow:0 1px 3px #0000000a}.section-title{color:var(--primary);align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:700;display:flex}.section-title:before{content:"";background:var(--primary);border-radius:2px;width:4px;height:14px}.section-label{color:var(--text2);letter-spacing:1px;margin:20px 2px 10px;font-size:11px;font-weight:800}.tag{border-radius:8px;align-items:center;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.tag-success{color:#065f46;background:#d1fae5}.tag-warn{color:#92400e;background:#fef3c7}.tag-info{color:#1d4ed8;background:#dbeafe}.tag-danger{color:#991b1b;background:#fee2e2}.tag-pending{color:#92400e;background:#fef3c7}.tag-bank{color:#1d4ed8;background:#dbeafe}.tag-done{color:#065f46;background:#d1fae5}.btn-primary{cursor:pointer;color:#fff;background:linear-gradient(135deg,#002147,#003b80);border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;padding:14px 16px;font-size:16px;font-weight:700;transition:transform .12s;display:flex;box-shadow:0 4px 14px #00214759}.btn-primary:active{transform:scale(.98)}.btn-ghost{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text2);cursor:pointer;border-radius:14px;justify-content:center;align-items:center;padding:14px 16px;font-size:14px;font-weight:700;display:flex}.func-group{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:6px;overflow:hidden;box-shadow:0 1px 4px #00000008}.func-item{color:inherit;border-bottom:1px solid #f5f5f5;align-items:center;gap:12px;padding:14px 16px;text-decoration:none;transition:background .1s;display:flex}.func-item:last-child{border-bottom:none}.func-item:active{background:#f9fafb}.func-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;display:flex}.func-icon.blue{background:#dbeafe}.func-icon.green{background:#dcfce7}.func-icon.orange{background:#ffedd5}.func-icon.purple{background:#f3e8ff}.func-icon.gold{background:#fef3c7}.func-icon.red{background:#fee2e2}.func-icon.gray{background:#f3f4f6}.func-text{flex:1;min-width:0}.func-text h4{margin-bottom:2px;font-size:14px;font-weight:700}.func-text p{color:var(--text2);font-size:11px;line-height:1.35}.func-badge{border-radius:8px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:800}.func-badge.warn{color:#92400e;background:#fef3c7}.func-badge.info{color:#1d4ed8;background:#dbeafe}.func-badge.success{color:#166534;background:#dcfce7}.func-arrow{color:#d1d5db;flex-shrink:0;font-size:14px}.filter-tabs{-webkit-overflow-scrolling:touch;gap:0;padding:14px 0 6px;display:flex;overflow-x:auto}.filter-tab{color:var(--text2);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:20px;flex-shrink:0;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s}.filter-tab.active{background:var(--primary);color:#fff}
