:root{--primary: #22c55e;--primary-strong: #16a34a;--primary-soft: #dcfce7;--primary-softer: #f0fdf4;--bg: #f8faf9;--surface: #ffffff;--surface-low: #f1f5f3;--surface-mid: #e7ece9;--border: #e5e7eb;--border-strong: #d1d5db;--text: #1a1c1a;--text-muted: #5c5f5c;--text-faint: #9ca3a0;--danger: #ef4444;--warn: #f59e0b;--info: #3b82f6;--ok: var(--primary);--radius-sm: 8px;--radius: 16px;--radius-lg: 24px;--radius-pill: 999px;--sp-xs: 4px;--sp-sm: 8px;--sp-md: 16px;--sp-lg: 24px;--sp-xl: 32px;--sp-2xl: 48px;--shadow-card: 0 1px 2px rgba(34, 197, 94, .04), 0 4px 16px rgba(34, 197, 94, .05);--shadow-card-hover: 0 2px 4px rgba(34, 197, 94, .06), 0 8px 24px rgba(34, 197, 94, .08);--shadow-nav: 0 -2px 12px rgba(0, 0, 0, .04);--shadow-pop: 0 8px 32px rgba(34, 197, 94, .12);--topnav-h: 64px;--bottomnav-h: 64px;--content-max: 1440px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{overflow-x:hidden}body{font-family:Public Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:14px;line-height:1.5;overflow-x:hidden}input,textarea,select{font-size:16px}table,td,th{word-break:break-word;overflow-wrap:anywhere}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4{font-family:Public Sans,system-ui,sans-serif;margin:0;letter-spacing:-.01em}h1{font-size:22px;font-weight:700}h2{font-size:18px;font-weight:700}h3{font-size:16px;font-weight:600}@media (min-width: 768px){h1{font-size:28px}h2{font-size:20px}}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;vertical-align:middle;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.app-shell{min-height:100%;display:flex;flex-direction:column}.app-content{flex:1;width:100%;max-width:var(--content-max);margin:0 auto;padding:var(--sp-md) var(--sp-md);padding-bottom:calc(var(--sp-lg) + var(--bottomnav-h))}@media (min-width: 480px){.app-content{padding:var(--sp-lg);padding-bottom:calc(var(--sp-xl) + var(--bottomnav-h))}}@media (min-width: 1024px){.app-content{padding-bottom:var(--sp-2xl);padding-left:var(--sp-xl);padding-right:var(--sp-xl)}}.topnav{display:none;height:var(--topnav-h);background:var(--surface);border-bottom:1px solid var(--border);align-items:center;padding:0 var(--sp-xl);gap:var(--sp-xl);position:sticky;top:0;z-index:50}@media (min-width: 1024px){.topnav{display:flex}}.topnav-brand{display:flex;align-items:center;gap:var(--sp-sm);font-weight:700;font-size:16px;letter-spacing:-.01em}.topnav-logo{width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:800}.topnav-links{display:flex;gap:var(--sp-sm);flex:1}.topnav-link{padding:8px 14px;border-radius:var(--radius-pill);color:var(--text-muted);font-weight:500;font-size:14px;transition:background .12s,color .12s}.topnav-link:hover{background:var(--surface-low);color:var(--text)}.topnav-link.active{background:var(--primary-soft);color:var(--primary-strong);font-weight:600}.mobilenav{display:flex;height:56px;align-items:center;justify-content:space-between;padding:0 var(--sp-md);background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}@media (min-width: 1024px){.mobilenav{display:none}}.bottomnav{display:flex;height:var(--bottomnav-h);background:var(--surface);border-top:1px solid var(--border);position:fixed;bottom:0;left:0;right:0;z-index:50;box-shadow:var(--shadow-nav)}@media (min-width: 1024px){.bottomnav{display:none}}.bottomnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;color:var(--text-muted);font-size:11px;font-weight:500;padding:6px 0;text-decoration:none;-webkit-tap-highlight-color:transparent}.bottomnav-item.active{color:var(--primary-strong)}.bottomnav-item.active .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 600}.bottomnav-item .material-symbols-outlined{font-size:24px}.brand-selector{position:relative}.brand-selector-btn{display:flex;align-items:center;gap:var(--sp-sm);min-height:44px;padding:8px 14px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-pill);font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;max-width:60vw;overflow:hidden;text-overflow:ellipsis;transition:border-color .12s,background .12s}.brand-selector-btn:hover{border-color:var(--primary);background:var(--primary-softer)}.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--primary)}.brand-dot.unconfigured{background:var(--text-faint)}.brand-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:240px;box-shadow:var(--shadow-pop);padding:6px;z-index:60}.brand-menu-item{display:flex;align-items:center;gap:var(--sp-sm);min-height:44px;padding:10px 12px;border-radius:10px;cursor:pointer;color:var(--text);width:100%;text-align:left;border:0;background:transparent;font-size:14px}.brand-menu-item:hover{background:var(--surface-low)}.brand-menu-item.active{background:var(--primary-softer);color:var(--primary-strong);font-weight:600}.brand-menu-item .meta{margin-left:auto;font-size:11px;color:var(--text-faint)}.brand-menu-item.unconfigured .meta{color:var(--warn)}.page-header{display:flex;flex-direction:column;gap:var(--sp-xs);margin-bottom:var(--sp-lg)}.page-header .subtitle{color:var(--text-muted);font-size:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-md);box-shadow:var(--shadow-card);min-width:0}@media (min-width: 480px){.card{padding:var(--sp-lg)}}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-md);gap:var(--sp-md)}.card-title{font-size:14px;font-weight:600;color:var(--text-muted)}.card-title-strong{font-size:16px;font-weight:700;color:var(--text)}.kpi-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-md);margin-bottom:var(--sp-lg)}@media (min-width: 480px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 768px){.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.kpi-grid.inner-3{grid-template-columns:1fr}@media (min-width: 480px){.kpi-grid.inner-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-md);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:6px;min-width:0}@media (min-width: 480px){.kpi{padding:var(--sp-lg)}}.kpi-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.kpi-value{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--text)}@media (min-width: 480px){.kpi-value{font-size:28px}}.kpi-sub{font-size:12px;color:var(--text-muted)}.kpi-delta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--primary-strong);background:var(--primary-soft);padding:2px 8px;border-radius:var(--radius-pill);width:fit-content}.kpi-delta.negative{color:var(--danger);background:#fee2e2}.chart-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-md);margin-bottom:var(--sp-lg)}@media (min-width: 1024px){.chart-grid.two-col{grid-template-columns:2fr 1fr}.chart-grid.split{grid-template-columns:1fr 1fr}}.chart-box{height:240px;width:100%;min-width:0}@media (min-width: 768px){.chart-box{height:280px}}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--sp-md));padding:0 var(--sp-md)}@media (min-width: 480px){.table-wrap{margin:0;padding:0}}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 12px;text-align:left;font-size:13px;border-bottom:1px solid var(--border)}.table th{font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;background:var(--surface-low)}.table tbody tr:hover{background:var(--surface-low)}.table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.table td.page-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (min-width: 768px){.table td.page-cell{max-width:360px}}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);background:var(--surface-low);color:var(--text-muted);font-size:11px;font-weight:600}.chip.ok{background:var(--primary-soft);color:var(--primary-strong)}.chip.warn{background:#fef3c7;color:#b45309}.chip.muted{background:var(--surface-low);color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--sp-2xl) var(--sp-lg);background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-muted);gap:var(--sp-sm)}.empty-state .icon{width:56px;height:56px;border-radius:50%;background:var(--primary-softer);color:var(--primary-strong);display:grid;place-items:center;margin-bottom:var(--sp-sm)}.empty-state .icon .material-symbols-outlined{font-size:32px}.empty-state h3{color:var(--text)}.empty-state p{max-width:480px;line-height:1.6}.empty-state code{background:var(--surface-low);padding:2px 6px;border-radius:4px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;color:var(--text)}.skeleton{background:linear-gradient(90deg,var(--surface-low) 0%,var(--surface-mid) 50%,var(--surface-low) 100%);background-size:200% 100%;animation:shimmer 1.6s infinite linear;border-radius:8px}.skeleton.kpi-shim{height:90px}.skeleton.chart-shim{height:280px}.skeleton.row-shim{height:24px;margin-bottom:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.recharts-cartesian-axis-tick text{font-size:11px;fill:var(--text-muted)}.recharts-tooltip-wrapper{outline:none}.chart-tooltip{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;box-shadow:var(--shadow-pop);font-size:12px}.chart-tooltip .label{color:var(--text-muted);margin-bottom:4px}.chart-tooltip .row{display:flex;align-items:center;gap:6px}.chart-tooltip .row .swatch{width:10px;height:10px;border-radius:3px}.chart-tooltip .row .v{font-weight:600;color:var(--text);margin-left:auto}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-sm);padding:var(--sp-2xl) var(--sp-lg);background:var(--surface);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-muted);cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.upload-zone:hover,.upload-zone.dragging{border-color:var(--primary);background:var(--primary-softer);color:var(--primary-strong)}.upload-zone .upload-icon{font-size:40px;color:var(--primary);margin-bottom:var(--sp-xs)}.upload-zone strong{font-size:15px;color:var(--text)}.upload-hint{font-size:13px}.uploaded-files{display:flex;flex-wrap:wrap;gap:var(--sp-sm);margin-bottom:var(--sp-lg)}.file-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--primary-soft);color:var(--primary-strong);border-radius:var(--radius-pill);font-size:12px;font-weight:600}.file-chip button{background:none;border:none;padding:0;line-height:1;color:inherit;opacity:.6;font-size:16px}.file-chip button:hover{opacity:1}.tab-bar{display:flex;gap:4px;margin-bottom:var(--sp-lg);border-bottom:1px solid var(--border);padding-bottom:0}.tab-btn{padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:14px;font-weight:500;color:var(--text-muted);transition:color .12s,border-color .12s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary-strong);border-bottom-color:var(--primary);font-weight:600}.btn-primary{display:inline-flex;align-items:center;gap:var(--sp-sm);padding:10px 20px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-pill);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,opacity .12s;white-space:nowrap}.btn-primary:hover{background:var(--primary-strong)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.settings-input{height:40px;padding:0 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:inherit;font-size:14px;width:100%;transition:border-color .12s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.settings-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #22c55e1f}.settings-input::placeholder{color:var(--text-faint)}select.settings-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235c5f5c' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.settings-recipient-grid{grid-template-columns:1fr!important}}
