.app-shell{min-height:100vh;background:radial-gradient(circle at 20% 0%,#e2f4ea,#f6f8f7 45%,#eef3f1);color:#12251c}.app-frame{max-width:1280px;margin:0 auto;padding:24px;display:grid;gap:16px}.app-frame.chart-screen-frame{max-width:none;width:100%}.panel-grid{display:grid;grid-template-columns:1fr;gap:16px}.panel{background:#fff;border:1px solid #d6dfda;border-radius:12px;padding:16px;box-shadow:0 2px 10px #0f20180f}.panel h2,.panel h3{margin-top:0}.panel h1 a{color:inherit;text-decoration:none}.panel h1 a:hover{text-decoration:underline}.page-title-row{justify-content:space-between;flex-wrap:wrap;row-gap:10px}.title-link-button{border:0;background:transparent;color:#12251c;font-size:clamp(1.35rem,2.5vw,2rem);font-weight:700;padding:0;text-align:left;display:inline-flex;align-items:center;gap:10px}.title-link-button:hover{color:#1f6f4d;text-decoration:underline}.title-logo-mark{width:32px;height:32px;flex:0 0 32px;display:block}.row{display:flex;gap:8px;align-items:center}.stack{display:grid;gap:8px}input,select,button,textarea{font:inherit}input,select,textarea{width:100%;border:1px solid #c5d1ca;border-radius:8px;padding:8px;background:#fbfdfc}button{border:1px solid #1f6f4d;border-radius:8px;padding:8px 12px;background:#1f6f4d;color:#fff;cursor:pointer}button.ghost{background:#fff;color:#1f6f4d}button.danger{border-color:#b23a2f;background:#b23a2f}button:disabled{opacity:.6;cursor:default}.chart-icon-button{width:38px;height:38px;min-width:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-color:#1f6f4d;background:#fff;color:#1f6f4d}.chart-outline-icon{width:20px;height:20px}.project-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.project-item{border:1px solid #d3ddd7;border-radius:8px;padding:10px;display:grid;gap:8px;cursor:pointer}.project-item:focus-visible{outline:2px solid #1f6f4d;outline-offset:2px}.project-item.active{border-color:#1f6f4d;background:#f0faf5}.project-datasets{border-top:1px solid #d3ddd7;padding-top:8px}.project-datasets h3{margin:0;font-size:.95rem}.project-name-button{border:0;background:transparent;color:#18392c;font-weight:700;padding:0;text-align:left}.project-name-button:hover{color:#1f6f4d;text-decoration:underline}.project-name-input{max-width:420px;min-width:180px}.storage-warning{border:1px solid #e2c77c;background:#fff9e8;color:#6b4b0f;border-radius:8px;padding:8px 10px;font-size:.9rem}.muted{color:#52675d;font-size:.9rem}.dataset-name-wrap{min-width:0;display:flex;align-items:center;gap:6px}.dataset-name-button{border:0;background:transparent;color:#18392c;padding:0;line-height:1.2;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:420px}.dataset-name-button:hover{color:#1f6f4d;text-decoration:underline}.dataset-name-input{max-width:420px;min-width:180px}.preview-wrap{overflow:auto;border:1px solid #d6dfda;border-radius:10px;max-height:360px}.preview-table{width:100%;border-collapse:collapse;font-size:.9rem}.preview-table th,.preview-table td{border-bottom:1px solid #edf1ef;padding:8px;text-align:left;vertical-align:top}.warning-list{margin:0;padding-left:18px}.import-popover-backdrop{position:fixed;inset:0;z-index:25;background:#0c1f1773;padding:20px;display:flex;justify-content:center;align-items:flex-start}.import-popover{width:min(980px,calc(100vw - 40px));max-height:calc(100vh - 40px);display:grid;gap:12px;grid-template-rows:auto 1fr auto;overflow:hidden}.import-popover-header{display:flex;justify-content:space-between;align-items:center}.import-popover-header h2{margin:0}.popover-x{width:36px;min-width:36px;height:36px;padding:0}.import-popover-body{overflow:auto;padding-right:4px}.import-popover-footer{justify-content:flex-end}.help-popover-backdrop{position:fixed;inset:0;z-index:40;background:#0c1f1773;padding:20px;display:flex;justify-content:center;align-items:flex-start}.help-popover{width:min(760px,calc(100vw - 40px));max-height:calc(100vh - 40px);display:grid;gap:12px;grid-template-rows:auto 1fr;overflow:hidden}.help-popover-header{display:flex;justify-content:space-between;align-items:center}.help-popover-header h2{margin:0}.help-popover-body{overflow:auto;padding-right:4px}.delete-confirm-backdrop{position:fixed;inset:0;z-index:35;background:#0c1f1773;padding:20px;display:flex;justify-content:center;align-items:flex-start}.delete-confirm-dialog{width:min(520px,calc(100vw - 40px));display:grid;gap:10px}.delete-confirm-actions{justify-content:flex-end}.chart-settings-popover-backdrop{position:fixed;inset:0;z-index:30;background:#0c1f1773;padding:20px;display:flex;justify-content:center;align-items:flex-start}.chart-settings-popover{width:min(860px,calc(100vw - 40px));max-height:calc(100vh - 40px);display:grid;gap:12px;grid-template-rows:auto 1fr auto;overflow:hidden}.chart-settings-popover-header{display:flex;justify-content:space-between;align-items:center}.chart-settings-popover-header h2{margin:0}.chart-settings-popover-body{overflow:auto;padding-right:4px}.chart-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.chart-color-input{width:52px;min-width:52px;padding:3px}.chart-dimension-row select{width:118px;min-width:118px}.chart-settings-popover-footer{justify-content:flex-end}.chart-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}.chart-layout.is-details-hidden{grid-template-columns:minmax(0,1fr)}.chart-surface{background:#fff;border:1px solid #d6dfda;border-radius:12px;padding:12px;min-height:0}.chart-canvas{width:100%;height:600px;display:block}.chart-toolbar{flex-wrap:wrap}.chart-header{justify-content:space-between;flex-wrap:wrap;row-gap:10px}.chart-header-title{display:inline-flex;align-items:center;gap:8px}.chart-title-logo{width:32px;height:32px;flex:0 0 32px;display:block}.chart-header-actions{margin-left:auto;min-width:0;justify-content:flex-end;flex-wrap:wrap}.chart-dataset-select{width:auto;min-width:180px;max-width:420px}.chart-collapse-wrap{border:1px solid #c5d1ca;border-radius:8px;padding:6px 10px;background:#fff}.chart-collapse-wrap input[type=checkbox]{width:auto;margin:0}.chart-breadcrumbs{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.crumb{border:1px solid #bfd2c8;background:#f4faf7;color:#194533;border-radius:999px;padding:5px 10px;line-height:1.2}.crumb.is-current{border-color:#175d3f;background:#1f6f4d;color:#fff}.chart-surface-krona{background:radial-gradient(circle at 50% 40%,#f9fdfb,#f4faf7 38%,#ebf3ee),#fff}.chart-canvas-krona{height:clamp(560px,calc(100vh - 270px),1400px);overflow:visible;animation:chart-fade-in .22s ease-out}.chart-layout.is-details-hidden .chart-canvas-krona{height:clamp(620px,calc(100vh - 230px),1600px)}.chart-wedge{cursor:pointer;transition:opacity .16s ease,stroke-width .18s ease,filter .16s ease}.chart-wedge:focus,.chart-wedge:focus-visible,.chart-key-callout:focus,.chart-key-callout:focus-visible{outline:none}.chart-wedge:hover{filter:brightness(1.07) saturate(1.06)}.chart-wedge.is-active{filter:brightness(1.08) saturate(1.12)}.chart-wedge.is-focus{filter:saturate(1.14)}.chart-wedge-label{fill:#0e2b1f;font-size:11px;font-weight:600;pointer-events:none;text-rendering:geometricPrecision}.chart-label-tooltip{pointer-events:none}.chart-label-tooltip-box{fill:#fff}.chart-label-tooltip-text{fill:#102a1f;font-weight:600}.chart-key-callout{cursor:pointer}.chart-key-callout.is-active .chart-key-line{stroke-width:1.3}.chart-key-callout.is-focus .chart-key-line{stroke:#1f6f4d}.chart-key-line{fill:none;stroke:#111;stroke-linecap:round;stroke-linejoin:round}.chart-key-text-box{fill:#fff}.chart-key-text{fill:#102a1f;font-weight:600}.chart-key-color-box{shape-rendering:geometricPrecision}.chart-center-disc{fill:#f4faf7;stroke:#c4d8cc;stroke-width:1.4;cursor:pointer;transition:fill .18s ease}.chart-center-disc:hover{fill:#e9f5ee}.chart-center-title{font-size:10px;font-weight:700;fill:#102a1f}.chart-center-metric{font-size:11px;font-weight:700;fill:#174936}.chart-center-sub{font-size:9px;fill:#4f675d}.chart-hint{text-align:center}.chart-details{max-height:700px;overflow:auto}.chart-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.chart-stat{border:1px solid #d4e1db;border-radius:10px;background:#f7fbf9;padding:8px;display:grid;gap:2px}.members-popover-trigger{width:100%}.members-popover-layer{position:fixed;left:0;right:0;top:90px;z-index:70;display:flex;justify-content:center;pointer-events:none}.members-popover{display:flex;flex-direction:column;gap:10px;animation:chart-fade-in .18s ease}.members-popover-floating{width:min(380px,calc(100vw - 32px));height:320px;pointer-events:auto}.members-popover-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.members-popover-list{flex:1;border:1px solid #d3dfd9;border-radius:10px;background:#fff;overflow-y:auto;padding:8px;display:grid;align-content:start;gap:6px}.members-popover-item{color:#234133;font-size:13px;line-height:1.35;word-break:break-word}.members-popover-footer{display:flex;justify-content:flex-end}.key-row{border:1px solid #d0ddd6;background:#fff;color:#1c3d30;border-radius:8px;padding:8px 10px;width:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px}.key-row:hover{border-color:#96b9a8;background:#f4faf7}.key-row.is-active{border-color:#1f6f4d;background:#e8f4ed}.key-label{text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.key-value{font-variant-numeric:tabular-nums;color:#335a4a}@keyframes chart-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@media(max-width:980px){.panel-grid{grid-template-columns:1fr}.import-popover-backdrop{padding:10px}.import-popover{width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.delete-confirm-backdrop{padding:10px}.delete-confirm-dialog{width:calc(100vw - 20px)}.chart-settings-popover-backdrop{padding:10px}.chart-settings-popover{width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.help-popover-backdrop{padding:10px}.help-popover{width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.chart-settings-grid{grid-template-columns:1fr}}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:99px;margin-right:6px}@media(max-width:980px){.panel-grid,.chart-layout{grid-template-columns:1fr}.chart-surface{min-height:480px}.chart-canvas{height:460px}.chart-canvas-krona{height:500px}.chart-layout.is-details-hidden .chart-canvas-krona{height:540px}.chart-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.members-popover-layer{top:70px}.members-popover-floating{width:calc(100vw - 20px);height:300px}}:root{font-family:IBM Plex Sans,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;color:#102018;background:#f6f8f7}main{max-width:900px;margin:0 auto;padding:24px}h1{margin-top:0}code{background:#e7ece9;border-radius:4px;padding:2px 6px}
