:root{font-family:Avenir Next,Segoe UI,sans-serif;color:#0f172a;background:#e2e8f0}*{box-sizing:border-box}body{margin:0;overflow-x:hidden}.app-shell{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#e2e8f0);overflow-x:hidden}.topbar{padding:16px 20px;display:flex;flex-direction:column;gap:12px;border-bottom:1px solid #cbd5e1;background:#fffc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.topbar-main{display:flex;justify-content:space-between;align-items:center;gap:12px}.topbar h1{margin:0;font-size:22px}.primary-nav{display:flex;gap:12px;flex-wrap:wrap}.nav-link{color:#334155;text-decoration:none;padding:6px 10px;border-radius:8px;display:inline-flex;align-items:center;gap:8px}.nav-link-badge{display:none}.topbar .auth-btn{color:#334155;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;cursor:pointer}.topbar .auth-btn:hover{background:#e2e8f0}.nav-link.active{background:#0f172a;color:#f8fafc}.content{padding:18px;max-width:1200px;margin:0 auto;display:grid;gap:14px;min-width:0}.panel{border:1px solid #cbd5e1;border-radius:14px;background:#fff;padding:14px;box-shadow:0 8px 20px #0f172a0f;min-width:0}.panel h2{margin:0 0 10px}.source-selector-panel{display:grid;gap:12px}.source-selector-header{display:flex;align-items:center;justify-content:space-between;min-width:0}.source-selector-header h2{margin:0;font-size:18px;line-height:1.1}.source-selector-fields{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.source-field{display:grid;gap:8px;min-width:0}.source-field-label{color:#475569;font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.source-field select,.period-field select,.period-field input,.controls input,.controls input[type=date],.controls select{background:#f8fafc;border-color:#cbd5e1;box-shadow:inset 0 1px #ffffffe6}.source-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 12px;border:1px solid #cbd5e1;border-radius:12px;background:#f8fafc;min-height:44px}.source-toggle-copy{display:grid;gap:2px;min-width:0}.source-toggle-text{color:#0f172a;font-size:14px;font-weight:600}.source-toggle input[type=checkbox]{width:18px;height:18px;margin:0}.period-panel{display:grid;gap:12px}.period-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.period-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;min-width:0}.period-field{display:grid;gap:8px;min-width:0}.period-field-label{color:#475569;font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.period-actions{flex-wrap:wrap}.period-shortcuts{display:grid;gap:8px}.controls{display:flex;align-items:center;gap:8px;min-width:0}.controls-wrap{flex-wrap:wrap}.controls input{width:120px;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;min-height:52px;font-size:16px}.controls input[type=checkbox]{width:auto;padding:0;border:0;border-radius:0}.checkbox-inline{display:inline-flex;align-items:center;gap:4px}.checkbox-right{order:99}.controls input[type=date]{width:160px}.controls select{min-width:180px;max-width:100%;min-height:52px;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;background:#f8fafc;font-size:16px}.controls select[multiple]{min-height:120px;min-width:300px}.controls button{padding:6px 10px;border:1px solid #94a3b8;border-radius:8px;background:#f8fafc;color:#0f172a;cursor:pointer}.controls button:hover{background:#e2e8f0}.config-editor{width:100%;min-height:420px;padding:10px 12px;border:1px solid #94a3b8;border-radius:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.5;resize:vertical}.login-cta{font-size:18px;font-weight:700;padding:12px 20px;border:1px solid #334155;border-radius:12px;background:#0f172a;color:#f8fafc;cursor:pointer}.login-cta:hover{background:#1e293b}.quick-actions{display:inline-flex;gap:6px}.muted{color:#64748b}.error{color:#b91c1c}.chart-legend{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.legend-item{display:inline-flex;align-items:center;gap:6px;color:#334155;font-size:13px}.legend-color{width:10px;height:10px;border-radius:999px}.chart-summary{margin:0 0 8px;font-size:13px;line-height:1.45;color:#0f172a;font-weight:500}.chart-summary-emphasis{font-size:14px;font-weight:600}.chart-summary strong,.chart-selected strong,.chart-total-prefix{font-weight:600;color:#0f172a}.chart-selected{margin:0 0 10px;font-size:13px;line-height:1.45;color:#0f172a;font-weight:500}.detail-list{margin:6px 0 10px 22px;padding:0}.detail-list-small{font-size:12px;line-height:1.4;color:#475569}.detail-list-small li+li{margin-top:2px}.declaration-callout{margin:12px 0 8px}.declaration-tax-value{color:#b91c1c;font-weight:700}.declaration-panel{display:flex;flex-direction:column;gap:14px}.declaration-header{flex-wrap:wrap}.declaration-header h2{margin:0}.declaration-body{width:100%}.declaration-body>*:first-child{margin-top:0}.chart-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:4px;max-width:100%;-webkit-overflow-scrolling:touch}.chart-with-axis{display:flex;align-items:flex-start;gap:8px;min-width:max-content}.y-axis{min-width:44px;height:262px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;color:#64748b;font-size:11px;font-weight:600;padding-right:4px;padding-bottom:26px}.y-axis-tick{line-height:1}.chart-plot{min-width:0;flex:1}.bars-wrap{overflow-x:auto;display:flex;align-items:flex-end;gap:0;padding-bottom:6px}.bar-group-row{overflow-x:auto;display:flex;align-items:flex-end;margin-bottom:4px}.bar-group-label{text-align:center;font-size:11px;font-weight:700;color:#334155}.bar-col{min-width:26px;display:flex;flex-direction:column;align-items:center;gap:6px}.bar-value{font-size:10px;color:#334155;white-space:nowrap}.bar-shell{width:20px;height:100%;border-radius:8px;background:#e2e8f0;display:flex;align-items:flex-end;overflow:hidden}.bar-shell-button{border:0;background:transparent;padding:0;width:20px;cursor:pointer}.bar-shell-button.is-selected .bar-shell{outline:2px solid #0f172a;outline-offset:2px}.bar-stack{width:100%;display:flex;flex-direction:column-reverse}.bar-segment{width:100%}.bar-label{font-size:11px;color:#475569;font-weight:600;min-height:16px;text-align:center;white-space:nowrap}.bar-label.delta-up{color:#b91c1c}.bar-label.delta-down{color:#15803d}.bar-label.delta-flat{color:#64748b}pre{margin:0;overflow:auto;max-height:60vh;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px;font-size:12px}@media (max-width: 768px){.topbar{padding:14px 14px 10px;gap:10px}.topbar-main{width:100%;align-items:flex-start}.topbar h1{font-size:18px}.topbar .auth-btn{padding:8px 10px;font-size:13px;line-height:1.2;max-width:150px}.primary-nav{position:sticky;bottom:0;width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(68px,1fr));gap:8px;padding:10px 0 2px;background:linear-gradient(180deg,#fffffff0,#f8fafcfa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-link{min-height:52px;padding:8px 6px;flex-direction:column;justify-content:center;gap:4px;border:1px solid #cbd5e1;background:#f8fafc}.nav-link-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:20px;padding:0 6px;border-radius:999px;background:#dbeafe;color:#1e3a8a;font-size:11px;font-weight:700;letter-spacing:.02em}.nav-link-label{font-size:11px;font-weight:700;line-height:1.1;text-align:center}.nav-link.active{border-color:#0f172a}.nav-link.active .nav-link-badge{background:#ffffff24;color:#f8fafc}.content{padding:14px}.chart-scroll{margin:0 -2px;padding:0 2px 6px}.controls{flex-wrap:wrap;align-items:stretch}.source-selector-panel{gap:12px}.source-selector-header h2{margin-bottom:0;font-size:17px}.source-field-label,.period-field-label{font-size:11px}.period-panel{gap:10px}.period-fields{grid-template-columns:minmax(0,1fr)}.period-header{align-items:flex-start}.period-shortcuts .quick-actions{flex-wrap:wrap}.source-toggle{padding:10px 12px;min-height:0}.source-toggle-text{font-size:13px}.source-selector-fields{gap:14px}.source-field select,.period-field select,.period-field input,.controls input,.controls input[type=date],.controls select{min-height:56px;font-size:17px}.controls>*{min-width:0}.controls input,.controls input[type=date],.controls select{width:100%;min-width:0;flex:1 1 100%}.controls select[multiple]{min-width:0;width:100%}.controls button{flex:0 0 auto}.checkbox-inline,.checkbox-right{width:100%;order:initial}.bar-col{min-width:24px}.bar-shell{width:18px}.y-axis{min-width:38px;font-size:10px}}@media (min-width: 769px) and (max-width: 1180px){.topbar{padding:14px 18px;gap:10px}.topbar-main{width:100%}.topbar h1{font-size:20px}.primary-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:10px;width:100%}.nav-link{min-height:50px;justify-content:center;padding:8px 10px;border:1px solid #cbd5e1;background:#f8fafc}.nav-link-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:20px;padding:0 6px;border-radius:999px;background:#dbeafe;color:#1e3a8a;font-size:11px;font-weight:700;letter-spacing:.02em}.nav-link-label{font-size:13px;font-weight:700}.nav-link.active{border-color:#0f172a}.nav-link.active .nav-link-badge{background:#ffffff24;color:#f8fafc}.content{padding:16px;max-width:100%}.source-selector-fields,.period-fields{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:14px}.source-selector-fields>.source-toggle{grid-column:1 / -1}.period-fields>.period-shortcuts{grid-column:1 / -1}.controls{flex-wrap:wrap;align-items:center}.controls select[multiple]{min-width:240px}.chart-scroll{max-width:100%}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: portrait){.primary-nav{grid-template-columns:repeat(4,minmax(0,1fr))}.topbar .auth-btn{max-width:180px}}@media (min-width: 769px) and (max-width: 1180px) and (orientation: landscape){.primary-nav{grid-template-columns:repeat(6,minmax(0,1fr))}.source-selector-fields{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr)}}
