:root{color-scheme:dark;--font-ui: Inter, Roboto, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--color-ink-1: #f4f7fb;--color-ink-2: #c7d0dd;--color-ink-3: #8793a3;--color-surface-0: #0b0f14;--color-surface-1: #121821;--color-surface-2: #1a222d;--color-surface-3: #223041;--color-line: #273344;--color-primary: #6da8ff;--color-primary-soft: #17365f;--color-blue: #89a7ff;--color-green: #4fd18b;--color-green-soft: #123b2a;--color-muted-chart: #354656;--color-orange: #ffb15d;--color-red: #ff6b66;--color-hover: #202b39;--color-row-hover: #17283a;--color-row-total: #1d2835;--color-table-head: #1a3a2c;--color-table-pin: #1a222d;--color-overlay: rgba(11, 15, 20, .58);--color-topbar: rgba(18, 24, 33, .9);--color-on-primary: #07111f;--color-code-bg: #090d12;--color-code-text: #dce7f5;--color-dashed-line: #364456;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 28px;--radius-pill: 100px;--shadow-sm: 0 10px 28px rgba(0, 0, 0, .22);--shadow-md: 0 18px 48px rgba(0, 0, 0, .36);--sidebar-width: 200px;--sidebar-collapsed-width: 63px;--style-sidebar-width: 200px;--style-sidebar-collapsed-width: 63px;--md-ref-typeface-brand: var(--font-ui);--md-ref-typeface-plain: var(--font-ui);--md-sys-color-primary: var(--color-primary);--md-sys-color-on-primary: var(--color-on-primary);--md-sys-color-surface: var(--color-surface-1);--md-sys-color-on-surface: var(--color-ink-1);--md-sys-color-on-surface-variant: var(--color-ink-2);--md-sys-color-outline: var(--color-line);--md-sys-shape-corner-full: var(--radius-pill)}:root[data-theme=light]{color-scheme:light;--color-ink-1: #1f2933;--color-ink-2: #515966;--color-ink-3: #8e949c;--color-surface-0: #f5f6f8;--color-surface-1: #ffffff;--color-surface-2: #f1f3f6;--color-surface-3: #e7ebf1;--color-line: #e6e9ee;--color-primary: #2f73d8;--color-primary-soft: #e9f1ff;--color-blue: #6b85d8;--color-green: #31b86b;--color-green-soft: #e8f8ef;--color-muted-chart: #c9dade;--color-orange: #f5a13a;--color-red: #ef5148;--color-hover: #f7f9fc;--color-row-hover: #f2faf6;--color-row-total: #f4f5f7;--color-table-head: #e2f2ea;--color-table-pin: #f1f3f6;--color-overlay: rgba(245, 246, 248, .24);--color-topbar: rgba(255, 255, 255, .88);--color-on-primary: #ffffff;--color-code-bg: #20242a;--color-code-text: #edf2f7;--color-dashed-line: #cfd5dd;--shadow-sm: 0 6px 20px rgba(22, 34, 51, .06);--shadow-md: 0 14px 36px rgba(22, 34, 51, .11);--md-sys-color-on-primary: var(--color-on-primary);--md-sys-color-surface: var(--color-surface-1);--md-sys-color-on-surface: var(--color-ink-1);--md-sys-color-on-surface-variant: var(--color-ink-2);--md-sys-color-outline: var(--color-line)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-width:320px;background:var(--color-surface-0);color:var(--color-ink-1);font-family:var(--font-ui);font-size:14px;line-height:1.4}button,input,textarea,select{font:inherit}button,input,textarea,select{color:inherit}button{margin:0;letter-spacing:0}h1,h2,h3,h4,h5,h6,p{display:block;margin:0;margin-block:0;margin-inline:0;font:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;letter-spacing:0}ul,ol{display:block;margin:0;margin-block:0;margin-inline:0;padding:0;padding-inline:0;list-style:none}img,svg{display:block}code{font-family:SFMono-Regular,Consolas,monospace}table{width:100%;border-collapse:collapse;font-size:12px}th,td{padding:8px 10px;border-bottom:1px solid var(--color-line);text-align:left;white-space:nowrap;font-weight:400}th{color:var(--color-ink-3);font-size:11px;font-weight:400}.app-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr)}.app-shell.nav-collapsed{grid-template-columns:var(--sidebar-collapsed-width) minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:20px;padding:10px 12px;border-right:1px solid var(--color-line);background:var(--color-surface-1)}.app-shell.nav-collapsed .sidebar{padding-inline:10px}.brand{display:flex;align-items:center;gap:12px;min-height:60px}.app-shell.nav-collapsed .brand{justify-content:center}.brand-mark{width:45px;height:53px;display:grid;place-items:center;flex:0 0 auto;overflow:visible}.brand-mark img{width:85%;height:85%;display:block;object-fit:contain}.app-shell.nav-collapsed .brand-mark{width:32px;height:37px}.brand-title,.brand span{display:block}.brand span,.sidebar-heading,.topbar-kicker{color:var(--color-ink-3);font-size:12px}.sidebar-group{display:grid;gap:6px}.sidebar-heading{padding:0 10px 4px;font-weight:400;text-transform:uppercase}.sidebar-toggle{width:100%;min-height:24px;display:flex;align-items:center;justify-content:flex-start;padding:0 10px;border:0;border-radius:0;background:transparent;color:var(--color-ink-3);cursor:pointer}.sidebar-toggle:hover{color:var(--color-primary)}.nav-item{width:100%;min-height:42px;display:flex;align-items:center;gap:10px;padding:0 10px;border:0;border-radius:var(--radius-md);background:transparent;color:var(--color-ink-2);cursor:pointer}.app-shell.nav-collapsed .brand div:not(.brand-mark),.app-shell.nav-collapsed .sidebar-heading,.app-shell.nav-collapsed .nav-item span,.app-shell.nav-collapsed .nav-item em,.app-shell.nav-collapsed .nav-chevron,.app-shell.nav-collapsed .sidebar-footer span{display:none}.app-shell.nav-collapsed .nav-item,.app-shell.nav-collapsed .sidebar-footer,.app-shell.nav-collapsed .sidebar-toggle{justify-content:center;padding-inline:0}.nav-item.active{background:var(--color-primary-soft);color:var(--color-primary);font-weight:400}.nav-item.ghost{cursor:default}.nav-item em{margin-left:auto;padding:3px 7px;border-radius:var(--radius-pill);background:var(--color-green-soft);color:var(--color-green);font-size:11px;font-style:normal}.nav-chevron{margin-left:auto}.sidebar-footer{margin-top:auto;min-height:42px;display:flex;align-items:center;gap:9px;padding:0 10px;border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-ink-3);font-size:13px;text-decoration:none;transition:color .15s ease,background .15s ease}.sidebar-footer:hover{background:var(--color-hover);color:var(--color-ink-2)}.sidebar-footer img{width:22px;height:22px;display:block;flex:0 0 auto;object-fit:contain}.workspace{min-width:0}.topbar{position:sticky;top:0;z-index:5;height:68px;display:flex;align-items:center;justify-content:flex-start;gap:18px;padding:0 24px;border-bottom:1px solid var(--color-line);background:var(--color-topbar);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar h1{font-size:19px;font-weight:500;line-height:1.15}.topbar-title-row{min-width:0;display:flex;align-items:center;gap:10px}.mobile-menu-button{display:none}.topbar-slot{flex:1;min-width:0}.topbar-actions{display:flex;align-items:center;gap:9px;margin-left:auto}.search-field{width:260px;height:38px;display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);color:var(--color-ink-3)}.search-field input{width:100%;border:0;outline:0;background:transparent;color:var(--color-ink-1)}.page{padding:12px 12px 22px}@media(max-width:980px){.app-shell{grid-template-columns:var(--sidebar-collapsed-width) minmax(0,1fr)}.sidebar{padding-inline:10px}.brand div:not(.brand-mark),.sidebar-heading,.sidebar-toggle span,.nav-item span,.nav-item em,.sidebar-footer span{display:none}.nav-item,.sidebar-toggle{justify-content:center}.search-field,.hide-mobile{display:none}.topbar{padding-inline:18px}}@media(max-width:700px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.topbar{min-height:92px;height:auto;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px 10px;padding:18px 16px}.topbar-title-row{grid-column:1;grid-row:1}.mobile-menu-button{display:grid;flex:0 0 auto}.topbar-slot,.topbar-slot>*{grid-column:1 / -1;grid-row:2;width:100%}.topbar-actions{grid-column:2;grid-row:1;position:static;margin-left:0}.page{padding:13px 13px 22px}}@media(max-width:420px){.topbar h1{max-width:calc(100vw - 202px);font-size:18px}}.mobile-menu-open{overflow:hidden}.mobile-menu-layer{position:fixed;inset:0;z-index:90;display:none}.mobile-menu-backdrop{position:absolute;inset:0;border:0;background:#0000006b}.mobile-menu-panel{position:absolute;top:0;bottom:0;left:0;width:min(310px,86vw);display:grid;align-content:start;gap:14px;padding:18px;border-right:1px solid var(--color-line);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--color-ink-1);font-size:18px;font-weight:500}.mobile-menu-list{display:grid;gap:8px}.mobile-menu-list.secondary{padding-top:12px;border-top:1px solid var(--color-line)}.mobile-menu-item{min-height:46px;display:flex;align-items:center;gap:12px;padding:0 12px;border:0;border-radius:var(--radius-md);background:transparent;color:var(--color-ink-2);cursor:pointer;text-align:left}.mobile-menu-item.active{background:var(--color-primary-soft);color:var(--color-primary)}@media(max-width:700px){.mobile-menu-layer{display:block}}.dashboard-page,.planfact-page,.settings-page,.style-content{display:grid;gap:14px}.hero-panel,.metric-card,.chart-frame,.table-card,.insight-card,.style-sidebar,.showcase-card,.component-example,.token-editor{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.hero-panel{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px}.section-kicker{margin-bottom:6px;color:var(--color-primary);font-size:12px;font-weight:500;text-transform:uppercase}.hero-panel h2,.style-header h2{font-size:clamp(20px,3vw,25px);font-weight:500;line-height:1.12}.hero-panel p,.style-header p,.panel-heading p,.component-example p,.insight-card p{color:var(--color-ink-3)}.hero-actions{display:flex;gap:10px}.metric-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.metric-card{min-height:98px;padding:11px 11px 11px 15px}.metric-label{color:var(--color-ink-3);font-size:13px;font-weight:400}.metric-value{display:block;margin-top:1px;font-size:25px;font-weight:500}.metric-delta{display:flex;align-items:center;gap:5px;margin-top:1px;font-size:13px;font-weight:400}.metric-delta small{color:var(--color-ink-3);font-weight:500}.metric-delta.good{color:var(--color-green)}.metric-delta.bad{color:var(--color-red)}.metric-delta.neutral{color:var(--color-ink-3)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(300px,.82fr);gap:18px}.side-stack{display:grid;gap:18px}.chart-frame{min-width:0;padding:18px}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.dashboard-topbar-controls{display:flex;align-items:center;gap:9px;min-width:0}.mobile-selector-row{display:none}.report-selectors.inline{min-width:0}.report-selector-grid{display:grid;grid-template-columns:minmax(190px,1fr) repeat(2,minmax(150px,.72fr));gap:8px;align-items:start}.report-selectors.inline .report-selector-grid,.dashboard-topbar-controls .report-selector-grid{display:flex;align-items:center;gap:9px;min-width:0}.report-selector-control{position:relative;min-width:0}.report-selector-trigger{width:100%;height:34px;display:inline-flex;align-items:center;gap:7px;max-width:250px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-1);color:var(--color-ink-2);cursor:pointer;font-weight:400;white-space:nowrap}.report-selector-trigger:hover{border-color:var(--color-dashed-line);color:var(--color-ink-1)}.report-selector-trigger span{min-width:0;overflow:hidden;text-overflow:ellipsis}.report-selector-trigger em{min-width:20px;height:20px;display:inline-grid;place-items:center;border-radius:var(--radius-pill);background:var(--color-surface-2);color:var(--color-ink-3);font-size:11px;font-style:normal;font-weight:400}.period-selector .report-selector-trigger{min-width:170px}.report-selector-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:45;display:grid;gap:8px;padding:10px;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.filter-layer{position:fixed;inset:0;z-index:85;display:none}.filter-layer-backdrop{position:absolute;inset:0;border:0;background:#00000070}.filter-layer-panel{position:absolute;left:12px;right:12px;top:92px;display:grid;gap:12px;max-height:calc(100dvh - 104px);overflow:auto;padding:14px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.filter-layer-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--color-ink-1);font-size:17px;font-weight:500}.period-menu{width:310px}.dictionary-menu{width:280px}.period-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.period-fields label{display:grid;gap:5px;color:var(--color-ink-3);font-size:11px}.period-fields input{width:100%;min-height:32px;padding:0 8px;border:1px solid var(--color-line);border-radius:var(--radius-sm);color:var(--color-ink-2);font:inherit;font-size:12px}.quick-preset-list{display:flex;flex-wrap:wrap;gap:6px}.quick-preset-list button{min-height:28px;padding:0 8px;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-1);color:var(--color-ink-2);cursor:pointer;font-size:12px;font-weight:400}.quick-preset-list button:hover{background:var(--color-surface-2)}.compact-filter{position:relative}.compact-filter-trigger{height:38px;display:inline-flex;align-items:center;gap:8px;max-width:250px;padding:0 12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);color:var(--color-primary);cursor:pointer;font-weight:400;white-space:nowrap}.compact-filter-trigger span{min-width:0;overflow:hidden;text-overflow:ellipsis}.compact-filter-trigger em{min-width:22px;height:22px;display:inline-grid;place-items:center;border-radius:var(--radius-pill);background:var(--color-primary-soft);color:var(--color-primary);font-style:normal;font-size:12px}.month-trigger{min-width:136px}.compact-filter-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:40;width:260px;display:grid;gap:10px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.month-menu{width:292px;grid-template-columns:repeat(2,minmax(0,1fr))}.month-menu label{display:grid;gap:5px;color:var(--color-ink-3);font-size:12px;font-weight:400}.month-menu input{width:100%;min-height:36px;padding:0 8px;border:1px solid var(--color-line);border-radius:var(--radius-sm);color:var(--color-ink-1);font-weight:400}.compact-filter-actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:6px}.compact-filter-actions button,.compact-apply-button{min-height:32px;border:0;border-radius:var(--radius-sm);cursor:pointer;font-weight:400}.compact-filter-actions button{padding:0 9px;background:var(--color-surface-2);color:var(--color-ink-2)}.compact-apply-button{grid-column:1 / -1;background:var(--color-primary);color:var(--color-on-primary)}.compact-option-list{display:grid;gap:4px;max-height:260px;overflow:auto}.compact-option-row{display:grid;gap:4px;padding:3px;border-radius:var(--radius-sm)}.compact-option-row:hover{background:var(--color-surface-2)}.compact-option-main{min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 8px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-ink-1);cursor:pointer;font-weight:400;text-align:left}.compact-option-main:hover{background:var(--color-hover)}.chart-frame.large{min-height:408px}.panel-heading{display:flex;justify-content:space-between;gap:16px;margin-bottom:12px}.panel-heading h2{font-size:16px;font-weight:500;line-height:1.2}.panel-heading.compact{margin-bottom:6px}.legend-list{display:flex;flex-wrap:wrap;gap:10px 14px;color:var(--color-ink-2);font-size:13px}.legend-list span{display:inline-flex;align-items:center;gap:6px}.legend-list i{width:9px;height:9px;border-radius:50%}.insight-card{display:grid;grid-template-columns:44px 1fr;gap:12px;padding:16px}.insight-card md-assist-chip{grid-column:2;justify-self:start}.insight-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--radius-md);background:var(--color-green-soft);color:var(--color-green);font-weight:500}.data-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:18px}.table-card{min-width:0;padding:16px}.table-scroll{width:100%;overflow:auto}.status-chip{display:inline-flex;padding:4px 8px;border-radius:var(--radius-pill);background:var(--color-green-soft);color:var(--color-green);font-weight:400}.dashboard-notice{display:grid;gap:8px;padding:18px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.dashboard-notice h3{font-size:16px;font-weight:400}.dashboard-notice p{color:var(--color-ink-3)}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--color-ink-3);font-size:14px}.local-login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:var(--color-surface-0)}.local-login-card{width:min(360px,100%);display:grid;gap:14px;padding:22px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.local-login-card h1{font-size:20px;font-weight:400}.local-login-card p,.local-login-card span,.local-login-error{color:var(--color-ink-3);font-size:13px}.local-login-card label{display:grid;gap:6px}.local-login-card input{height:38px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-1);color:var(--color-ink-1)}.local-login-card button{height:40px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-primary);color:var(--color-on-primary);cursor:pointer}.local-login-card button:disabled{opacity:.65;cursor:default}.local-login-error{color:var(--color-red)}.dashboard-loading-overlay{position:fixed;inset:0;z-index:80;display:grid;place-items:center;pointer-events:none;background:var(--color-overlay);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.dashboard-loading-card{min-width:220px;display:grid;justify-items:center;gap:8px;padding:20px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.loading-title{font-size:15px;font-weight:400}.dashboard-loading-card span{color:var(--color-ink-3);font-size:13px}.loading-percent{color:var(--color-ink-3);font-size:12px}.loading-ring{width:38px;height:38px;border:4px solid var(--color-primary-soft);border-top-color:var(--color-primary);border-radius:50%;animation:loading-spin .8s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.selector-panel{display:grid;gap:12px;padding:16px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.selector-grid{display:grid;grid-template-columns:1.25fr repeat(3,minmax(180px,1fr));gap:12px;align-items:start}.selector-control{position:relative;display:grid;gap:7px}.selector-label{color:var(--color-ink-2);font-size:13px;font-weight:400}.date-range-control,.multi-select-trigger,.multi-select-search{min-height:42px;display:flex;align-items:center;gap:8px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);color:var(--color-ink-2)}.date-range-control{padding:0 10px}.date-range-control input{min-width:0;border:0;outline:0;background:transparent;color:var(--color-ink-1);font-weight:400}.quick-range-list{display:flex;flex-wrap:wrap;gap:6px}.quick-range-list button,.select-all-button,.only-button{min-height:30px;border:0;border-radius:var(--radius-sm);background:var(--color-surface-2);color:var(--color-ink-2);cursor:pointer;font-weight:400}.quick-range-list button{padding:0 9px;font-size:12px}.multi-select{position:relative}.multi-select-trigger{width:100%;justify-content:space-between;padding:0 10px;cursor:pointer}.multi-select-trigger span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-ink-1);font-weight:400}.multi-select-trigger em{min-width:26px;height:26px;display:grid;place-items:center;border-radius:var(--radius-sm);background:var(--color-primary-soft);color:var(--color-primary);font-style:normal;font-weight:400}.multi-select-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:20;width:min(360px,92vw);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding:10px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);box-shadow:var(--shadow-md)}.multi-select-search{padding:0 9px;background:var(--color-surface-2)}.multi-select-search input{min-width:0;width:100%;border:0;outline:0;background:transparent}.multi-select-search button{border:0;background:transparent;color:var(--color-ink-3);cursor:pointer}.select-all-button{padding:0 12px}.multi-select-options{grid-column:1 / -1;max-height:280px;overflow:auto;display:grid;gap:3px}.multi-select-option{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:center}.multi-select-option>button:first-child{min-height:36px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 10px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-ink-1);cursor:pointer;font-weight:400;text-align:left}.multi-select-option>button:first-child:hover{background:var(--color-surface-2)}.multi-select-option svg{color:var(--color-primary)}.only-button{padding:0 10px;opacity:0}.option-actions{display:flex;gap:6px}.multi-select-option:hover .only-button,.compact-option-row:hover .only-button{opacity:1}.selector-empty{padding:10px;color:var(--color-ink-3)}.align-left{text-align:left}.planfact-panel{min-width:0;display:grid;gap:10px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.planfact-header{display:flex;align-items:end;justify-content:space-between;gap:12px}.planfact-header h2{font-size:17px;font-weight:500;line-height:1.15}.planfact-header p{max-width:680px;color:var(--color-ink-3);font-size:12px;line-height:1.35;text-align:right}.planfact-filters.report-selectors.inline .report-selector-grid,.planfact-filters .report-selector-grid{display:grid;grid-template-columns:minmax(260px,1.2fr) minmax(160px,.55fr) minmax(220px,.8fr);gap:8px;align-items:start}.planfact-table-scroll{width:100%;overflow:auto;border:1px solid var(--color-line);border-radius:var(--radius-sm)}.planfact-table{width:max-content;min-width:100%;border-collapse:collapse;table-layout:fixed;font-size:12px}.planfact-table th,.planfact-table td{width:74px;min-width:74px;padding:5px 6px;border-bottom:1px solid var(--color-line);border-left:1px solid var(--color-line);text-align:right;vertical-align:top;font-weight:400}.planfact-table th{position:sticky;top:0;z-index:1;background:var(--color-table-head);color:var(--color-ink-1);font-size:12px}.planfact-table tbody tr:last-child td{border-bottom:0}.planfact-table .city-col,.planfact-table .metric-col{position:sticky;left:0;z-index:2;width:104px;min-width:104px;border-left:0;background:var(--color-table-pin);text-align:left}.planfact-table th.city-col,.planfact-table th.metric-col{z-index:3;background:var(--color-table-head)}.planfact-compare-table{width:100%}.planfact-compare-table th,.planfact-compare-table td{width:88px;min-width:88px}.table-sort-button{width:100%;display:inline-flex;align-items:center;justify-content:flex-end;gap:3px;padding:0;border:0;background:transparent;color:inherit;cursor:pointer;font:inherit;text-align:inherit}.align-left .table-sort-button,.city-col .table-sort-button,.metric-col .table-sort-button{justify-content:flex-start}.sort-arrow{color:var(--color-ink-3);font-size:10px;line-height:1}.interactive-table tbody tr:hover td,.planfact-table tbody tr:hover td,.interactive-table th.col-hover,.interactive-table td.col-hover,.planfact-table th.col-hover,.planfact-table td.col-hover{background:var(--color-row-hover)}.interactive-table tbody tr.total-row td,.planfact-table tbody tr.total-row td,.planfact-table tbody tr.total-row .city-col{background:var(--color-row-total)}.interactive-table tbody tr.total-row:hover td,.planfact-table tbody tr.total-row:hover td{background:var(--color-hover)}.cell-main,.cell-sub,.metric-title,.metric-note{display:block}.cell-main,.metric-title{color:var(--color-ink-1);font-size:12px;font-weight:400;line-height:1.18}.cell-sub,.metric-note{margin-top:2px;color:var(--color-ink-3);font-size:11px;line-height:1.18}.positive{color:var(--color-green)}.negative{color:var(--color-red)}.planfact-state{min-height:24px;display:inline-flex;align-items:center;gap:6px;color:var(--color-ink-3);font-size:12px}.planfact-state.error{color:var(--color-red)}.settings-panel,.settings-block{display:grid;gap:14px;padding:18px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.settings-list{display:grid;gap:14px}.settings-block.disabled{opacity:.62}.settings-block-header,.settings-actions,.settings-mini-title{display:flex;align-items:center;gap:10px}.settings-block-header{justify-content:space-between}.settings-block-header h3{font-size:16px;font-weight:500}.settings-block-header p,.settings-mini-title{color:var(--color-ink-3);font-size:13px}.settings-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.settings-field{display:grid;gap:6px;color:var(--color-ink-2);font-size:13px;font-weight:500}.settings-switch{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-ink-2)}.settings-switch input{position:relative;width:42px;height:22px;flex:0 0 42px;appearance:none;border:0;border-radius:var(--radius-pill);background:var(--color-line);cursor:pointer}.settings-switch input:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--color-surface-1);box-shadow:var(--shadow-sm);transition:transform .16s ease}.settings-switch input:checked{background:var(--color-primary)}.settings-switch input:checked:after{transform:translate(20px)}.settings-switch span{display:grid;gap:3px}.settings-switch .text-main{color:var(--color-ink-1);font-weight:400}.settings-switch small{color:var(--color-ink-3);font-size:13px}.settings-switch.compact{padding:8px 10px}.settings-switch.compact input{width:34px;height:18px;flex-basis:34px}.settings-switch.compact input:after{top:3px;left:3px;width:12px;height:12px}.settings-switch.compact input:checked:after{transform:translate(16px)}.settings-field input,.settings-field select,.settings-field textarea{width:100%;min-height:38px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-sm);outline:none;background:var(--color-surface-1);color:var(--color-ink-1)}.settings-field textarea{min-height:84px;padding-block:10px;resize:vertical}.metric-picker{display:grid;gap:10px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2)}.metric-picker-grid{display:flex;flex-wrap:wrap;gap:8px}.metric-toggle{min-height:34px;display:inline-flex;align-items:center;gap:7px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-1);color:var(--color-ink-2);font-size:13px}.metric-toggle.disabled{cursor:default;opacity:.42}.selector-editor,.target-block-list{display:grid;gap:10px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2)}.target-block-list{display:flex;flex-wrap:wrap}.selector-field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:8px}.selector-field-toggle{min-height:52px;display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);color:var(--color-ink-2)}.selector-field-toggle span{min-width:0;display:grid;gap:2px}.selector-field-toggle .text-main{overflow:hidden;color:var(--color-ink-1);font-size:13px;font-weight:400;text-overflow:ellipsis;white-space:nowrap}.selector-field-toggle small{overflow:hidden;color:var(--color-ink-3);font-family:SFMono-Regular,Consolas,monospace;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.selector-defaults{display:grid;gap:10px}.selector-default-card{display:grid;grid-template-columns:minmax(120px,.6fr) minmax(180px,1fr) minmax(220px,1fr) minmax(220px,1fr);gap:10px;align-items:center;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1)}.selector-default-card.disabled{opacity:.55}.selector-default-card>div{display:grid;gap:2px}.selector-default-card .text-main{font-weight:400}.selector-default-card small{color:var(--color-ink-3);font-family:SFMono-Regular,Consolas,monospace;font-size:12px}.refresh-note{display:flex;align-items:center;gap:8px;color:var(--color-ink-3);font-size:13px}.icon-button{position:relative;width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--color-line);border-radius:50%;background:var(--color-surface-1);color:var(--color-ink-2);cursor:pointer}.icon-button:disabled{cursor:default;opacity:.4}.notification-dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--color-red)}.avatar{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:var(--color-primary);color:var(--color-on-primary);font-size:13px;font-weight:500}.styles-layout{display:grid;grid-template-columns:var(--style-sidebar-width) minmax(0,1fr);gap:20px}.styles-layout.panels-collapsed{grid-template-columns:var(--style-sidebar-collapsed-width) minmax(0,1fr)}.style-sidebar{position:sticky;top:90px;align-self:start;display:grid;gap:6px;padding:12px}.styles-layout.panels-collapsed .style-sidebar{padding-inline:10px}.style-nav{min-height:42px;display:flex;align-items:center;gap:10px;border:0;border-radius:var(--radius-md);background:transparent;color:var(--color-ink-2);cursor:pointer}.styles-layout.panels-collapsed .style-nav{justify-content:center;padding-inline:0}.styles-layout.panels-collapsed .style-nav span{display:none}.style-nav.active{background:var(--color-surface-2);color:var(--color-ink-1);font-weight:500}.style-actions{display:flex;flex-wrap:wrap;gap:10px}.token-editor{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;padding:14px}.token-control{display:grid;gap:7px;color:var(--color-ink-2);font-size:13px}.token-control span{font-weight:500}.token-control input{width:100%;min-height:34px;border:1px solid var(--color-line);border-radius:var(--radius-sm);padding:0 8px}.token-control small{color:var(--color-ink-3);line-height:1.35}.edit-guide,.css-export,.class-catalog,.component-gallery,.css-file-editor{display:grid;gap:12px;padding:18px;border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface-1);box-shadow:var(--shadow-sm)}.style-workbench{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);gap:18px;align-items:start}.style-workbench .css-file-editor,.style-workbench .component-gallery{position:sticky;top:88px}.style-workbench .css-editor-grid{grid-template-columns:132px minmax(0,1fr)}.style-workbench .css-editor-textarea{min-height:560px}.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}.guide-card{display:grid;gap:7px;padding:14px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2)}.guide-card svg{color:var(--color-primary)}.guide-card p{color:var(--color-ink-3);font-size:13px;line-height:1.45}.css-editor-grid{display:grid;grid-template-columns:170px minmax(0,1fr);gap:12px}.css-editor-search{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:8px;align-items:center}.css-search-field{min-height:38px;display:flex;align-items:center;gap:8px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-ink-3)}.css-search-field input{width:100%;border:0;outline:0;background:transparent;color:var(--color-ink-1)}.css-search-field button,.search-nav-button{width:30px;height:30px;display:grid;place-items:center;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-ink-2);cursor:pointer}.search-nav-button{border:1px solid var(--color-line);background:var(--color-surface-1)}.search-nav-button:disabled{cursor:default;opacity:.42}.search-count{min-width:58px;color:var(--color-ink-2);font:12px/1.2 SFMono-Regular,Consolas,monospace;text-align:center}.search-count.muted{color:var(--color-ink-3)}.css-file-list{display:grid;align-content:start;gap:7px}.css-file-tab{min-height:38px;padding:0 12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-1);color:var(--color-ink-2);cursor:pointer;text-align:left}.css-file-tab.active{border-color:transparent;background:var(--color-primary-soft);color:var(--color-primary);font-weight:500}.css-editor-textarea{width:100%;min-height:420px;resize:vertical;padding:14px;border:1px solid var(--color-line);border-radius:var(--radius-md);outline:none;background:var(--color-code-bg);color:var(--color-code-text);font:12px/1.55 SFMono-Regular,Consolas,monospace}.css-editor-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 14%,transparent)}.editor-status{color:var(--color-ink-3);font-size:13px}.editor-status.dirty{color:var(--color-orange);font-weight:400}.css-export p{margin-top:4px;color:var(--color-ink-3)}.css-export pre{max-height:260px;overflow:auto;margin:0;padding:14px;border-radius:var(--radius-md);background:var(--color-code-bg);color:var(--color-code-text);font-size:12px;line-height:1.55}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}.class-row{display:grid;gap:6px;padding:12px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2)}.class-row code{color:var(--color-primary);font-weight:500}.class-row span{color:var(--color-ink-2);font-size:13px}.class-row small{color:var(--color-ink-3);font-family:SFMono-Regular,Consolas,monospace;font-size:11px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.compact-gallery .gallery-grid{grid-template-columns:1fr;max-height:680px;overflow:auto;padding-right:4px}.compact-gallery .component-preview{grid-template-columns:150px minmax(0,1fr);align-items:stretch}.compact-gallery .component-preview-surface{min-height:130px}.component-preview{display:grid;gap:10px;padding:14px;border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2)}.component-preview-meta{display:grid;gap:5px}.component-preview-meta code,.component-preview-meta small{color:var(--color-ink-3);font-size:12px}.component-preview-surface{min-height:118px;display:grid;align-items:center;padding:12px;border:1px dashed var(--color-dashed-line);border-radius:var(--radius-md);background:var(--color-surface-1);overflow:hidden}.mini-preview{box-shadow:none}.hero-panel.mini-preview{padding:16px}.hero-panel.mini-preview h2{font-size:clamp(20px,3vw,25px)}.preview-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.preview-nav{display:grid;gap:7px;width:min(210px,100%)}.preview-editor{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:center}.fake-code{min-height:48px;display:flex;align-items:center;padding:10px;border-radius:var(--radius-sm);background:var(--color-code-bg);color:var(--color-code-text);font:12px/1.4 SFMono-Regular,Consolas,monospace}.color-grid,.radius-grid,.showcase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.showcase-card,.component-example{padding:18px}.swatch div{height:58px;border-radius:var(--radius-md);border:1px solid var(--color-line)}.swatch code,.component-example code,.token-control code{color:var(--color-ink-3);font-size:12px}.swatch span,.swatch p{display:block;margin-top:6px;color:var(--color-ink-3);font-size:12px}.radius-sample,.example-surface{min-height:78px;display:grid;place-items:center;background:var(--color-surface-2);border:1px dashed var(--color-dashed-line);color:var(--color-ink-3);font-weight:400}.type-stack{display:grid;gap:12px}.type-stack h1{font-size:38px;font-weight:500;line-height:1.1}.type-stack h2{font-size:24px;font-weight:500;line-height:1.15}.hero-panel,.metric-card,.chart-frame,.table-card,.insight-card,.selector-panel,.settings-panel,.settings-block,.showcase-card,.component-example,.token-editor{border-color:var(--color-line);box-shadow:none}.hero-panel,.chart-frame,.table-card,.selector-panel,.settings-panel,.settings-block{border-radius:var(--radius-md)}.metric-card,.table-card,.chart-frame,.settings-panel,.settings-block,.selector-panel{padding:12px}.section-kicker,.metric-label,.selector-label,.settings-field,.settings-mini-title,.settings-block-header p,.panel-heading p,.component-example p,.insight-card p{color:var(--color-ink-3);font-size:11px;font-weight:400}.panel-heading h2,.settings-block-header h3,.dashboard-notice h3,.planfact-header h2{color:var(--color-ink-1);font-weight:400}.metric-value,.metric-card .text-main{font-size:22px;font-weight:400}.metric-delta,.status-chip,.loading-title,.settings-switch .text-main,.selector-field-toggle .text-main,.selector-default-card .text-main,.radius-sample,.select-all-button,.only-button,.quick-range-list button,.compact-apply-button,.multi-select-trigger span,.multi-select-trigger em,.multi-select-option>button:first-child,.compact-filter-trigger,.compact-option-main,.month-menu label,.month-menu input,.date-range-control input{font-weight:400}.report-selector-trigger,.multi-select-trigger,.date-range-control,.multi-select-search,.settings-field input,.settings-field select,.settings-field textarea,.compact-filter-trigger{min-height:34px;border-color:var(--color-line);border-radius:var(--radius-sm);color:var(--color-ink-2);font-size:12px;font-weight:400}.report-selector-menu,.multi-select-menu,.compact-filter-menu{gap:7px;padding:8px;border-color:var(--color-line);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.multi-select-search,.select-all-button,.only-button,.quick-range-list button,.quick-preset-list button,.compact-filter-actions button{background:var(--color-surface-2);color:var(--color-ink-3);font-size:12px}.select-all-button,.only-button{min-height:28px;padding:0 9px}.multi-select-options{gap:1px}.multi-select-option{gap:4px}.multi-select-option>button:first-child{min-height:30px;padding:0 8px;color:var(--color-ink-2);font-size:12px}.multi-select-option>button:first-child span{font-weight:400}.option-actions{gap:4px}.compact-apply-button{min-height:30px;background:var(--color-primary);font-size:12px}.planfact-table th,.planfact-table td{border-color:var(--color-line)}@media(max-width:1120px){.metric-grid,.chart-grid,.dashboard-grid,.data-grid,.planfact-filters .report-selector-grid,.report-selector-grid,.selector-grid,.selector-default-card{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid .chart-frame.large{grid-column:1 / -1}.token-editor{grid-template-columns:repeat(2,minmax(0,1fr))}.style-workbench{grid-template-columns:1fr}.style-workbench .css-file-editor,.style-workbench .component-gallery{position:static}.dashboard-topbar-controls,.report-selectors.inline .report-selector-grid,.dashboard-topbar-controls .report-selector-grid{width:100%;flex-wrap:wrap}.report-selectors.inline .report-selector-control,.dashboard-topbar-controls .report-selector-control{flex:1 1 180px}.report-selector-trigger,.compact-filter-trigger{max-width:none}}@media(max-width:760px){.hero-panel,.panel-heading{align-items:flex-start;flex-direction:column}.metric-grid,.chart-grid,.dashboard-grid,.data-grid,.planfact-filters .report-selector-grid,.report-selector-grid,.selector-grid,.selector-default-card,.settings-grid,.styles-layout,.style-workbench,.css-editor-grid,.token-editor{grid-template-columns:1fr}.style-workbench .css-file-editor,.style-workbench .component-gallery{position:static}.compact-gallery .component-preview{grid-template-columns:1fr}.style-sidebar{position:static}.metric-grid{gap:10px}.metric-card{min-height:auto}.chart-frame{padding:12px 10px}.period-menu,.dictionary-menu,.compact-filter-menu,.multi-select-menu{left:0;right:auto;width:min(100%,calc(100vw - 28px));max-width:calc(100vw - 28px)}.month-menu,.period-fields{grid-template-columns:1fr}.planfact-panel{padding:10px}.planfact-header{align-items:flex-start;flex-direction:column}.planfact-header p{max-width:none;text-align:left}.planfact-table th,.planfact-table td{width:70px;min-width:70px;padding:6px}.planfact-table .city-col,.planfact-table .metric-col{width:96px;min-width:96px}.settings-block-header,.settings-actions{align-items:flex-start;flex-direction:column}.css-editor-search{grid-template-columns:minmax(0,1fr) auto auto}.search-count{grid-column:1 / -1;text-align:left}}@media(max-width:700px){.report-selectors>.report-selector-grid,.report-selectors.inline>.report-selector-grid,.report-selectors.inline .report-selector-grid,.selector-panel>.report-selector-grid,.dashboard-topbar-controls>.report-selector-grid,.planfact-filters>.report-selector-grid,.planfact-filters.report-selectors.inline>.report-selector-grid,.planfact-filters.report-selectors.inline .report-selector-grid{display:none}.mobile-selector-row{display:flex;align-items:center;gap:8px;width:100%}.mobile-selector-period{min-width:0;flex:1 1 auto}.mobile-selector-period .report-selector-control,.mobile-selector-period .report-selector-trigger{width:100%}.mobile-selector-period .report-selector-trigger{max-width:none}.mobile-selector-button{min-width:58px;height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 10px;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-1);color:var(--color-ink-2);cursor:pointer}.mobile-selector-button em{min-width:20px;height:20px;display:inline-grid;place-items:center;border-radius:var(--radius-pill);background:var(--color-primary-soft);color:var(--color-primary);font-size:11px;font-style:normal}.filter-layer{display:block}.filter-layer-panel .selector-panel{padding:0;border:0;background:transparent;box-shadow:none}.filter-layer-panel>.report-selector-grid,.filter-layer-panel .report-selectors>.report-selector-grid,.filter-layer-panel .report-selectors.inline .report-selector-grid,.filter-layer-panel .planfact-filters.report-selectors.inline .report-selector-grid,.filter-layer-panel .report-selector-grid{display:grid;grid-template-columns:1fr}.filter-layer-panel .layer-selector-grid{display:grid!important;grid-template-columns:1fr;width:100%}.filter-layer-panel .mobile-selector-row{display:none}.filter-layer-panel .report-selector-trigger{max-width:none}.filter-layer-panel .report-selector-control{position:static}.filter-layer-panel .report-selector-menu{position:static;width:100%;max-width:none;margin-top:8px;box-shadow:none}.filter-layer-panel .period-menu,.filter-layer-panel .dictionary-menu{width:100%}.filter-layer-panel .multi-select-options{max-height:min(320px,calc(100dvh - 360px))}.planfact-filters.report-selectors.inline .report-selector-grid,.planfact-filters .report-selector-grid{width:100%;grid-template-columns:1fr}.planfact-filters .report-selector-control,.planfact-filters .report-selector-trigger,.planfact-filters .period-selector .report-selector-trigger{min-width:0;max-width:none;width:100%}}@media(max-width:420px){.hero-panel,.showcase-card,.component-example,.settings-panel,.settings-block,.edit-guide,.css-export,.class-catalog,.component-gallery,.css-file-editor{padding:12px}.metric-value,.metric-card .text-main{font-size:20px}.panel-heading h2,.planfact-header h2{font-size:15px}}
