:root{--bg: #0f172a;--bg-2: #1e293b;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #3b82f6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--radius: 10px;--shadow: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.04);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*{box-sizing:border-box}html,body{overscroll-behavior-y:contain}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;font-size:14px;background:var(--surface-2);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}#app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.nav-toggle{display:none;position:fixed;top:calc(12px + var(--safe-top));left:calc(12px + var(--safe-left));width:44px;height:44px;padding:0;background:var(--bg);border:none;border-radius:10px;cursor:pointer;z-index:60;align-items:center;justify-content:center;flex-direction:column;gap:4px;box-shadow:0 2px 8px #00000026}.nav-toggle span{display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:transform .2s,opacity .2s}.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:40;opacity:0;transition:opacity .2s}.nav-backdrop.show{opacity:1}.sidebar{background:var(--bg);color:#fff;padding:20px 12px;padding-top:calc(20px + var(--safe-top));padding-left:calc(12px + var(--safe-left));position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar .brand{font-size:18px;font-weight:700;padding:8px 12px 20px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar a{color:#cbd5e1;text-decoration:none;padding:10px 12px;border-radius:8px;font-size:14px;transition:background .15s}.sidebar a:hover{background:#ffffff0f;color:#fff}.sidebar a.active{background:var(--primary);color:#fff}main{padding:24px 32px;padding-right:calc(32px + var(--safe-right));max-width:1400px;min-width:0}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.page-header h1{margin:0;font-size:22px;font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--surface);border-radius:var(--radius);padding:16px 20px;border:1px solid var(--border);box-shadow:var(--shadow)}.kpi-card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.kpi-card .value{font-size:22px;font-weight:700}.kpi-card .sub{font-size:12px;color:var(--muted);margin-top:4px}.value.pos{color:var(--success)}.value.neg{color:var(--danger)}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}.section h2{margin:0 0 16px;font-size:16px;font-weight:600}.breakdown-list{display:flex;flex-direction:column;gap:10px}.breakdown-row{display:grid;grid-template-columns:180px 1fr 120px;align-items:center;gap:12px;font-size:13px}.breakdown-bar{background:var(--surface-2);height:8px;border-radius:4px;overflow:hidden}.breakdown-bar>div{height:100%;background:var(--primary);border-radius:4px;transition:width .3s}.breakdown-row .num{text-align:right;font-variant-numeric:tabular-nums}.pie-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.pie-svg{flex:0 0 auto;max-width:100%;height:auto}.pie-svg path,.pie-svg circle{stroke:var(--surface);stroke-width:2}.pie-slice-label{fill:#fff;font-size:12px;font-weight:600;pointer-events:none}.pie-legend{flex:1 1 260px;display:flex;flex-direction:column;gap:4px;min-width:0}.pie-legend-row{display:grid;grid-template-columns:14px 1fr auto auto;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;font-size:13px}.pie-legend-row.clickable{cursor:pointer}.pie-legend-row.clickable:hover{background:var(--surface-2)}.legend-dot{width:12px;height:12px;border-radius:3px;display:inline-block}.legend-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-value{font-variant-numeric:tabular-nums;color:var(--muted)}.legend-pct{font-variant-numeric:tabular-nums;font-weight:600;min-width:48px;text-align:right}.drill-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.drill-header h2{margin:0;font-size:16px;font-weight:600}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -20px;padding:0 20px}table{width:100%;border-collapse:collapse}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:13px;white-space:nowrap}th{background:var(--surface-2);font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}tr:hover{background:var(--surface-2)}td.num{text-align:right;font-variant-numeric:tabular-nums}.pos{color:var(--success)}.neg{color:var(--danger)}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;background:var(--surface-2);border:1px solid var(--border)}.badge.pos{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.badge.neg{background:#fef2f2;border-color:#fecaca;color:#991b1b}.member-chip{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;color:#fff;font-weight:600}button,.btn{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;min-height:36px}button:hover,.btn:hover{opacity:.9}button.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}button.danger{background:var(--danger)}button.small{padding:4px 10px;font-size:12px;min-height:28px}.toolbar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}input,select,textarea{padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:var(--surface);color:var(--text);min-height:36px;max-width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:-1px;border-color:var(--primary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);font-weight:500;min-width:0}.form-grid label.full{grid-column:span 2}.toast{position:fixed;bottom:calc(20px + var(--safe-bottom));right:calc(20px + var(--safe-right));left:calc(20px + var(--safe-left));max-width:400px;margin-left:auto;background:var(--bg);color:#fff;padding:12px 20px;border-radius:8px;opacity:0;transform:translateY(20px);transition:all .3s;pointer-events:none;z-index:1000;box-shadow:0 10px 30px #0003}.toast.show{opacity:1;transform:translateY(0)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;padding-top:calc(16px + var(--safe-top));padding-bottom:calc(16px + var(--safe-bottom))}.modal{background:var(--surface);border-radius:var(--radius);padding:24px;width:100%;max-width:540px;max-height:100%;overflow-y:auto;box-shadow:0 20px 50px #0003}.modal h3{margin:0 0 16px;font-size:18px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;flex-wrap:wrap}.empty{text-align:center;padding:40px 20px;color:var(--muted)}.loading{padding:40px;text-align:center;color:var(--muted)}@media (max-width: 768px){body{font-size:15px}#app{display:block;min-height:100vh}.nav-toggle{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;max-width:80vw;height:100dvh;z-index:50;transform:translate(-100%);transition:transform .25s ease;padding-top:calc(20px + var(--safe-top))}.sidebar.open{transform:translate(0)}.sidebar .brand{padding-left:56px}.sidebar a{padding:12px 14px;font-size:15px}main{padding:72px 16px calc(24px + var(--safe-bottom));padding-left:calc(16px + var(--safe-left));padding-right:calc(16px + var(--safe-right));max-width:100%}.page-header h1{font-size:18px}.page-header>button{white-space:nowrap}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.kpi-card{padding:12px 14px}.kpi-card .value{font-size:17px}.kpi-card .label{font-size:10px}.section{padding:14px;margin-bottom:14px}.section h2{font-size:14px}.breakdown-row{grid-template-columns:1fr;gap:6px}.breakdown-row .num{text-align:left}.pie-wrap{justify-content:center}.table-wrap{margin:0 -14px;padding:0 14px}table{font-size:13px}th,td{padding:10px 8px}.toolbar{gap:8px}.toolbar>input,.toolbar>select{flex:1 1 100%;min-width:0}.form-grid{grid-template-columns:1fr}.form-grid label.full{grid-column:span 1}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:14px 14px 0 0;max-height:92dvh;max-width:100%;padding:20px 16px calc(20px + var(--safe-bottom))}.modal-actions{justify-content:stretch}.modal-actions button{flex:1}button.small{min-height:32px;padding:6px 10px}input,select,textarea{font-size:16px}}@media (max-width: 380px){.kpi-grid{grid-template-columns:1fr}}body.nav-open{overflow:hidden}.muted-sm{color:var(--muted);font-size:11px}.chip-list{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 6px 4px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;font-size:12px;font-weight:500}.chip-x{background:transparent;color:var(--muted);border:none;padding:0 4px;font-size:13px;min-height:0;cursor:pointer;line-height:1}.chip-x:hover{color:var(--danger)}.group-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.group-card{border:1px solid var(--border);border-radius:var(--radius);padding:14px;background:var(--surface)}.group-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.group-card-head>div:first-child{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bank-select{position:relative}.bank-search{width:100%}.bank-results{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 30px #0000001f;max-height:240px;overflow-y:auto;z-index:110}.bank-row{padding:8px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid var(--border)}.bank-row:last-child{border-bottom:none}.bank-row:hover{background:var(--surface-2)}.bank-row strong{color:var(--primary);margin-right:4px}.bank-row .bank-short{color:var(--muted);font-size:11px;margin-left:4px}.bank-row-custom{font-style:italic;color:var(--muted)}.bank-row-custom strong{color:var(--text);font-style:normal}
