:root{--c-text: #1A2B3C;--c-text-secondary: #5A6B7C;--c-text-muted: #8A99A8;--c-text-on-accent: #fff;--c-page: #FAFBFC;--c-surface: #fff;--c-subtle: #F2F5F8;--c-hover: #F2F5F8;--c-active: #e2e8f0;--c-accent: #15314B;--c-accent-dark: #1E4A6B;--c-accent-light: #4FC1C0;--c-accent-bg: #E5F4F4;--c-success: #059669;--c-success-bg: #ecfdf5;--c-warning: #d97706;--c-warning-bg: #fffbeb;--c-error: #dc2626;--c-error-bg: #fef2f2;--c-tag-required-bg: #d1fadf;--c-tag-required-fg: #054f31;--c-tag-required-border: #6ce9a6;--c-tag-optional-bg: #d1e9ff;--c-tag-optional-fg: #194185;--c-tag-optional-border: #84caff;--c-tag-locked-bg: #fee4e2;--c-tag-locked-fg: #7a271a;--c-tag-locked-border: #fda29b;--c-tag-readonly-bg: #f2f4f7;--c-tag-readonly-fg: #344054;--c-tag-readonly-border: #d0d5dd;--c-tag-pending-bg: #fef0c7;--c-tag-pending-fg: #93370d;--c-tag-pending-border: #fec84b;--c-tag-success-bg: #d1fadf;--c-tag-success-fg: #054f31;--c-tag-success-border: #6ce9a6;--c-tag-warning-bg: #fef0c7;--c-tag-warning-fg: #93370d;--c-tag-warning-border: #fec84b;--c-tag-error-bg: #fee4e2;--c-tag-error-fg: #7a271a;--c-tag-error-border: #fda29b;--c-tag-info-bg: #e0eaff;--c-tag-info-fg: #2d31a6;--c-tag-info-border: #b4baff;--c-tag-neutral-bg: #f2f4f7;--c-tag-neutral-fg: #344054;--c-tag-neutral-border: #d0d5dd;--c-border: #DDE3EA;--c-border-strong: #C4CDD5;--c-border-focus: #4FC1C0;--font-sans: "Inter Tight", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: .9375rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--control-h-sm: 28px;--control-h-md: 36px;--control-h-lg: 44px;--r-sm: .375rem;--r-md: .5rem;--r-lg: .75rem;--r-full: 9999px;--shadow-sm: 0 1px 0 rgba(21,49,75,.04), 0 1px 2px rgba(21,49,75,.06);--shadow-md: 0 1px 0 rgba(21,49,75,.04), 0 6px 16px rgba(21,49,75,.08);--shadow-lg: 0 1px 0 rgba(21,49,75,.04), 0 24px 48px rgba(21,49,75,.18);--sidebar-w: 260px;--sidebar-w-collapsed: 64px;--z-sticky: 10;--z-modal: 100;--z-toast: 200;--color-surface-0: var(--c-surface);--color-surface-1: var(--c-page);--color-surface-2: var(--c-subtle);--color-surface-3: var(--c-active);--color-surface-default: var(--c-surface);--color-surface-raised: var(--c-surface);--color-surface-sunken: var(--c-subtle);--color-surface-overlay: var(--c-surface);--color-text-primary: var(--c-text);--color-text-secondary: var(--c-text-secondary);--color-text-muted: var(--c-text-muted);--color-text-tertiary: var(--c-text-muted);--color-text-on-accent: var(--c-text-on-accent);--color-text-on-danger: #ffffff;--color-border-subtle: var(--c-border);--color-border-default: var(--c-border);--color-border-strong: var(--c-border-strong);--color-status-success-bg: var(--c-success-bg);--color-status-success-fg: var(--c-success);--color-status-success-border: #6ce9a6;--color-status-warning-bg: var(--c-warning-bg);--color-status-warning-fg: var(--c-warning);--color-status-warning-border: #fec84b;--color-status-error-bg: var(--c-error-bg);--color-status-error-fg: var(--c-error);--color-status-error-border: #fda29b;--color-status-danger-bg: var(--c-error-bg);--color-status-danger-fg: var(--c-error);--color-status-danger-border: #fda29b;--color-status-info-bg: var(--c-accent-bg);--color-status-info-fg: var(--c-accent-dark);--color-status-info-border: #84caff;--color-status-neutral-bg: var(--c-subtle);--color-status-neutral-fg: var(--c-text-secondary);--color-status-neutral-border: var(--c-border);--color-accent-primary: var(--c-accent);--color-accent-primary-hover: var(--c-accent-dark);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-pill: 9999px;--elevation-low: 0 1px 2px rgba(15, 23, 42, .06);--elevation-mid: 0 4px 8px -2px rgba(15, 23, 42, .08), 0 2px 4px -2px rgba(15, 23, 42, .06);--elevation-high: 0 12px 24px -8px rgba(15, 23, 42, .16), 0 4px 8px -4px rgba(15, 23, 42, .08);--motion-duration-instant: 0ms;--motion-duration-quick: .12s;--motion-duration-base: .2s;--motion-duration-slow: .32s;--motion-ease-standard: cubic-bezier(.2, 0, 0, 1);--motion-ease-emphasized: cubic-bezier(.3, 0, 0, 1);--motion-ease-decelerate: cubic-bezier(0, 0, .2, 1);--duration-fast: var(--motion-duration-quick);--duration-normal: .18s;--easing-standard: var(--motion-ease-standard);--grad-pyramid: linear-gradient(180deg, #4FC1C0 0%, #2F7A93 45%, #15314B 100%);--shadow-focus: 0 0 0 2px var(--c-page), 0 0 0 4px #4FC1C0;--topbar-h: 64px;--d-micro: .12s;--d-ui: .2s;--ease: cubic-bezier(.2,.7,.2,1)}:focus-visible{outline:none;box-shadow:0 0 0 2px var(--c-surface),0 0 0 4px var(--c-accent)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);color:var(--c-text);background:var(--c-page);font-size:var(--text-base);line-height:1.5;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}::selection{background:#0d948826}.app-layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;flex:1 1 auto;min-height:0}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--c-subtle);border-right:1px solid var(--c-border);display:flex;flex-direction:column;padding:var(--sp-3) var(--sp-2);gap:var(--sp-3);overflow-y:auto;transition:width var(--d-ui) var(--ease),min-width var(--d-ui) var(--ease)}.sidebar.sidebar--collapsed{width:var(--sidebar-w-collapsed);min-width:var(--sidebar-w-collapsed)}.sidebar__top{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4)}.sidebar.sidebar--collapsed .sidebar__top{justify-content:center;padding:var(--sp-3) var(--sp-2)}.sidebar__product{font-size:13px;font-weight:500;color:var(--c-text);letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.sidebar--collapsed .sidebar__product{display:none}.sidebar__rail-toggle{flex:0 0 auto;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-full);color:var(--c-text-secondary);cursor:pointer;transition:background var(--d-micro) var(--ease),color var(--d-micro) var(--ease)}.sidebar__rail-toggle:hover{background:var(--c-active);color:var(--c-text)}.sidebar__nav,.sidebar__section{display:flex;flex-direction:column;gap:2px}.sidebar__section+.sidebar__section{margin-top:var(--sp-2)}.sidebar__section-label{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-muted);padding:var(--sp-2) var(--sp-3) 4px;flex:1;text-align:left}.sidebar.sidebar--collapsed .sidebar__section-label{display:none}.sidebar__item{position:relative;display:flex;align-items:center;gap:var(--sp-3);padding:6px var(--sp-3);border-radius:var(--r-md);color:var(--c-text-secondary);font-size:14px;font-weight:500;background:transparent;border:0;cursor:pointer;text-decoration:none;width:100%;text-align:left;transition:background var(--d-micro) var(--ease),color var(--d-micro) var(--ease)}.sidebar__item:hover{background:#15314b0d;color:var(--c-text)}.sidebar__item:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.sidebar__item--active{background:var(--c-surface);color:var(--c-accent);box-shadow:var(--shadow-sm)}.sidebar__item--active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--c-accent-light);border-radius:0 2px 2px 0}.sidebar__item-icon{display:inline-flex;flex:0 0 auto;width:16px;height:16px;align-items:center;justify-content:center}.sidebar__item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.sidebar--collapsed .sidebar__item{justify-content:center;padding:8px}.sidebar.sidebar--collapsed .sidebar__item-label{display:none}.sidebar.sidebar--collapsed .sidebar__item--active{background:var(--c-accent);color:var(--c-text-on-accent)}.sidebar.sidebar--collapsed .sidebar__item--active:before{display:none}.sidebar.sidebar--collapsed .sidebar__item--active .sidebar__item-icon{color:var(--c-text-on-accent)}.sidebar__group-toggle{display:flex;align-items:center;gap:var(--sp-2);background:transparent;border:0;cursor:pointer;font:inherit;color:var(--c-text-muted);padding:0 var(--sp-3);width:100%;text-align:left}.sidebar__group-toggle:hover{color:var(--c-text)}.sidebar__group-toggle:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:var(--r-md)}.sidebar__group-chevron{display:inline-flex;flex:0 0 auto;color:var(--c-text-muted);transition:transform var(--d-micro) var(--ease)}.sidebar__group-chevron--collapsed{transform:rotate(-90deg)}.sidebar.sidebar--collapsed .sidebar__group-toggle{display:none}.sidebar__group-children{display:flex;flex-direction:column;gap:2px;padding-left:var(--sp-2)}.sidebar.sidebar--collapsed .sidebar__group-children{padding-left:0}.sidebar__footer{padding-top:var(--sp-3);border-top:1px solid var(--c-border)}.sidebar__live{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);margin-top:auto;font-size:11px;color:var(--c-text-muted);letter-spacing:.04em}.sidebar__live-dot{width:6px;height:6px;border-radius:var(--r-full);background:var(--c-success);flex:0 0 auto;animation:sidebar-live-pulse 2s ease-in-out infinite}.sidebar__live-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes sidebar-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.sidebar.sidebar--collapsed .sidebar__live{justify-content:center;padding:var(--sp-2)}.sidebar.sidebar--collapsed .sidebar__live-label{display:none}@media(prefers-reduced-motion:reduce){.sidebar__live-dot{animation:none}.sidebar__group-chevron{transition:none}}.main{grid-column:2;padding:var(--sp-8) var(--sp-8) var(--sp-12);min-width:0}.page-header{display:flex;align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-6);flex-shrink:0}.page-header__title-block{display:flex;flex-direction:column;gap:var(--sp-1);min-width:0}.page-header__title-row{display:flex;align-items:center;gap:var(--sp-2)}.page-header h1,.page-header__title{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page-header__count{display:inline-flex;align-items:center;font-size:12px;font-family:var(--font-mono);color:var(--c-text-secondary);background:var(--c-subtle);border:1px solid var(--c-border);border-radius:var(--r-full);padding:1px 8px;line-height:1.4}.page-header__subtitle,.page-header p{margin:0;color:var(--c-text-secondary);font-size:var(--text-base);line-height:1.4}.page-header__sub-tabs{display:flex;align-items:center;gap:2px}.page-header__sub-tab{font-size:12px;padding:5px 10px;border-radius:var(--r-md);background:transparent;color:var(--c-text-secondary);border:0;cursor:pointer;font-weight:500}.page-header__sub-tab:hover{background:var(--c-hover);color:var(--c-text)}.page-header__sub-tab--active{background:var(--c-subtle);color:var(--c-text);font-weight:600}.page-header__grow{flex:1}.page-header__actions{display:flex;align-items:center;gap:var(--sp-2);margin-left:auto}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--sp-4);margin-bottom:var(--sp-8)}.kpi-card{padding:var(--sp-5);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg)}.kpi-card--warning{border-left:3px solid var(--c-warning)}.kpi-card--success{border-left:3px solid var(--c-success)}.kpi-card--accent{border-left:3px solid var(--c-accent)}button.kpi-card--clickable{cursor:pointer;font:inherit;color:inherit;text-align:left;width:100%;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}button.kpi-card--clickable:hover{transform:translateY(-1px);border-color:var(--c-accent);box-shadow:0 2px 8px #0000000f}button.kpi-card--clickable:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}.kpi-label{display:block;font-size:var(--text-xs);font-weight:500;color:var(--c-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-1)}.kpi-value{display:block;font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em;color:var(--c-text)}.kpi-note{display:block;font-size:var(--text-xs);color:var(--c-text-muted);margin-top:var(--sp-1)}.hero-actions{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--sp-6);margin-bottom:var(--sp-8)}.hero-primary{padding:var(--sp-8);background:linear-gradient(135deg,var(--c-accent-dark),var(--c-accent));border-radius:var(--r-lg);color:#fff}.hero-primary__head{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3)}.hero-primary__head strong{font-size:var(--text-xl);font-weight:700}.hero-primary p{color:#fffc;font-size:var(--text-base);margin:0 0 var(--sp-5);line-height:1.6}.hero-secondary{display:grid;gap:var(--sp-4)}.card{padding:var(--sp-5);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:border-color var(--duration-fast) var(--easing-standard),box-shadow var(--duration-fast) var(--easing-standard)}.card:hover{border-color:var(--c-border-strong)}.card--muted{background:var(--c-subtle)}.card--warning{border-left:3px solid var(--c-warning)}.card--compact{padding:var(--sp-3) var(--sp-4)}.card strong{display:block;font-size:var(--text-md);font-weight:600;margin-bottom:var(--sp-1)}.card p{margin:0 0 var(--sp-3);color:var(--c-text-secondary);font-size:var(--text-sm);line-height:1.5}.card small{display:block;color:var(--c-text-muted);font-size:var(--text-xs);margin-top:var(--sp-1)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);margin-top:var(--sp-4);margin-bottom:var(--sp-4);margin-inline:auto;gap:var(--sp-3)}.empty-state--compact{max-width:480px;padding:var(--sp-8) var(--sp-6)}.empty-state--rich{max-width:720px;padding:var(--sp-8) var(--sp-6)}.empty-state__icon{display:inline-flex;align-items:center;justify-content:center;color:var(--c-text-muted);margin-bottom:var(--sp-1)}.empty-state__title{margin:0;font-size:18px;font-weight:600;color:var(--c-text);letter-spacing:-.01em}.empty-state__subtitle{margin:0;font-size:13px;color:var(--c-text-secondary);max-width:50ch;line-height:1.5}.empty-state__welcome{margin:0 0 var(--sp-2);font-size:var(--text-lg);font-weight:600;color:var(--c-text);letter-spacing:-.01em}.empty-state__description{font-size:var(--text-sm);color:var(--c-text-secondary);max-width:420px;line-height:1.5;margin-bottom:var(--sp-5)}.empty-state__action{margin-top:var(--sp-4)}.empty-state--rich .empty-state__action{margin-top:0;margin-bottom:var(--sp-6)}.empty-state__section{width:100%;max-width:560px;text-align:left;margin-bottom:var(--sp-5)}.empty-state__section:last-child{margin-bottom:0}.empty-state__section-title{margin:0 0 var(--sp-3);font-size:var(--text-sm);font-weight:600;color:var(--c-text);text-transform:uppercase;letter-spacing:.04em}.empty-state__suggestions{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--sp-2)}.empty-state__suggestion{display:block;width:100%;text-align:left;padding:var(--sp-3);border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-subtle);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-standard),background var(--duration-fast) var(--easing-standard)}.empty-state__suggestion:hover{border-color:var(--c-border-strong);background:var(--c-hover)}.empty-state__suggestion-title{margin-bottom:var(--sp-1);font-weight:600;color:var(--c-text)}.empty-state__suggestion-description{font-size:var(--text-sm);color:var(--c-text-secondary)}.empty-state__examples{display:flex;flex-direction:column;gap:var(--sp-3);margin:0}.empty-state__example-term{font-size:var(--text-sm);font-weight:600;color:var(--c-text)}.empty-state__example-copy{margin-left:0;font-size:var(--text-sm);color:var(--c-text-secondary);line-height:1.5}.section{margin-bottom:var(--sp-8)}.section__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--sp-4)}.section__head h2{margin:0;font-size:var(--text-lg);font-weight:600;letter-spacing:-.01em}.section__head small{color:var(--c-text-muted);font-size:var(--text-xs)}.data-table{border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}.data-table--scroll{overflow:auto;max-height:calc(100vh - var(--data-table-scroll-offset, 230px));position:relative}.data-table__head{display:grid;gap:var(--sp-4);padding:var(--sp-2) var(--sp-3);background:var(--c-subtle);font-size:11px;font-weight:600;color:var(--c-text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--c-border)}.data-table__row{display:grid;gap:var(--sp-4);padding:var(--sp-2) var(--sp-3);background:var(--c-surface);border-top:1px solid var(--c-border);font-size:var(--text-sm);cursor:pointer;transition:background .1s;border:none;width:100%;text-align:left;min-height:36px;align-items:center}.data-table__row:first-of-type{border-top:none}.data-table__row:hover{background:var(--c-active)}.data-table__row--selected{background:var(--c-accent-bg)}.data-table__row strong{font-weight:500;color:var(--c-text)}.data-table__row small{color:var(--c-text-muted);font-size:var(--text-xs)}.data-table__head,.data-table__row{grid-template-columns:2fr .7fr .7fr .7fr 1fr}.data-table--dynamic-cols .data-table__head,.data-table--dynamic-cols .data-table__row{grid-template-columns:var(--data-table-cols, 2fr .7fr .7fr .7fr 1fr)}.data-table:not(.data-table--scroll) .data-table__head,.data-table:not(.data-table--scroll) .data-table__row{overflow:hidden}.data-table--scroll .data-table__head{position:sticky;top:0;z-index:2;width:max-content;min-width:100%}.data-table--scroll .data-table__row{width:max-content;min-width:100%}.data-table__cell,.table-header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.data-table__resize-handle{transition:background-color .12s ease,border-color .12s ease}.data-table__resize-handle:hover{background:var(--c-accent, #2563eb);opacity:.5}.data-table__resize-handle:active{background:var(--c-accent, #2563eb);opacity:.8}.badge{display:inline-block;padding:2px 8px;border-radius:var(--r-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.02em}.badge--accent{background:#2563eb1f;color:var(--c-accent)}.badge--success{background:var(--c-success-bg);color:var(--c-success)}.badge--warning{background:var(--c-warning-bg);color:var(--c-warning)}.badge--error{background:var(--c-error-bg);color:var(--c-error)}.badge--muted{background:var(--c-subtle);color:var(--c-text-secondary)}.badge--channel-internal{background:#dbeafe;color:#1e40af}.badge--channel-g2g{background:#fef3c7;color:#92400e}.badge--channel-external{background:#d1fae5;color:#065f46}.badge--healthy{background:var(--c-success-bg);color:var(--c-success)}.badge--stale{background:var(--c-warning-bg);color:var(--c-warning)}.badge--failed{background:var(--c-error-bg);color:var(--c-error)}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);height:var(--control-h-md);padding:0 var(--sp-3);line-height:1;border-radius:var(--r-md);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-standard),border-color var(--duration-fast) var(--easing-standard),box-shadow var(--duration-fast) var(--easing-standard),color var(--duration-fast) var(--easing-standard);border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text)}.btn:hover{background:var(--c-hover);border-color:var(--c-border-strong);box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn--primary{background:var(--c-accent);border-color:var(--c-accent);color:#fff}.btn--primary:hover{background:var(--c-accent-dark);border-color:var(--c-accent-dark);box-shadow:var(--shadow-sm)}.btn--secondary{background:var(--c-surface);border-color:var(--c-border);color:var(--c-text)}.btn--ghost{background:transparent;border-color:transparent;color:var(--c-accent)}.btn--ghost:hover{background:var(--c-accent-bg);box-shadow:none}.btn--danger{background:var(--c-error-bg);border-color:#fecaca;color:var(--c-error)}.btn--danger:hover{background:#fee2e2;border-color:#fca5a5;box-shadow:var(--shadow-sm)}.btn-group{display:flex;gap:var(--sp-3);flex-wrap:wrap}.grid{display:grid;gap:var(--sp-6)}.grid--2col{grid-template-columns:repeat(2,1fr)}.grid--3col{grid-template-columns:repeat(3,1fr)}.grid--auto{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-list{display:grid;gap:var(--sp-3)}.stat-row{display:grid;grid-template-columns:auto auto auto 1fr;gap:var(--sp-3);align-items:center;padding:var(--sp-2) 0}.progress-bar{height:6px;background:var(--c-subtle);border-radius:var(--r-full);overflow:hidden}.progress-bar__fill{height:100%;background:var(--c-accent);border-radius:inherit;transition:width .3s}.toolbar{display:flex;gap:var(--sp-3);align-items:center;flex-wrap:wrap;margin-bottom:var(--sp-4)}.toolbar input[type=search],.toolbar input[type=text]{flex:1;min-width:200px;padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--text-sm);background:var(--c-surface)}.toolbar input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px #2563eb1a;outline:none}.toolbar select{padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--text-sm);background:var(--c-surface)}.toolbar__meta{margin-left:auto;font-size:var(--text-xs);color:var(--c-text-muted)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--c-border);margin-bottom:var(--sp-5);flex-wrap:wrap;row-gap:2px}.tab{padding:var(--sp-2) var(--sp-4);border:none;background:none;font-size:var(--text-sm);font-weight:500;color:var(--c-text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px;white-space:nowrap;flex-shrink:0}.tab:hover{color:var(--c-text)}.tab--active{color:var(--c-accent);border-bottom-color:var(--c-accent);font-weight:600}.accordion{border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:var(--sp-3)}.accordion summary{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-3) var(--sp-5);cursor:pointer;font-size:var(--text-base);font-weight:500;list-style:none;background:var(--c-surface)}.accordion summary::-webkit-details-marker{display:none}.accordion[open] summary{border-bottom:1px solid var(--c-border);background:var(--c-subtle)}.accordion__body{padding:var(--sp-5)}.kv-grid{display:grid;grid-template-columns:max-content 1fr;gap:var(--sp-2) var(--sp-6);min-width:0}.kv-label{font-size:var(--text-sm);color:var(--c-text-secondary);font-weight:500;white-space:nowrap}.kv-value{font-size:var(--text-sm);color:var(--c-text);min-width:0;overflow-wrap:anywhere;word-break:break-word}.kv-value--breakall{word-break:break-all}.empty{padding:var(--sp-12) var(--sp-8);text-align:center}.empty--compact{padding:var(--sp-6) var(--sp-4)}.empty strong{display:block;font-size:var(--text-lg);margin-bottom:var(--sp-2)}.empty--compact strong{font-size:var(--text-base, 1rem);margin-bottom:var(--sp-1)}.empty p{color:var(--c-text-secondary);margin:0 0 var(--sp-5)}.toast-container{position:fixed;top:var(--sp-4);right:var(--sp-4);z-index:var(--z-toast);display:grid;gap:var(--sp-3)}.toast{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-3) var(--sp-5);border-radius:var(--r-lg);background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-lg);font-size:var(--text-sm);animation:slide-up .2s ease-out;max-width:420px}.toast--error{border-color:#fecaca;background:var(--c-error-bg);color:var(--c-error)}.toast--success{border-color:#a7f3d0;background:var(--c-success-bg);color:var(--c-success)}.toast button{border:none;background:none;font-weight:600;cursor:pointer;color:inherit;font-size:var(--text-xs)}.skeleton{background:linear-gradient(90deg,var(--c-subtle) 25%,var(--c-hover) 50%,var(--c-subtle) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--r-md)}.skeleton--card{height:120px}.skeleton--row{height:44px;margin-bottom:2px}.skeleton--text{height:14px;width:60%;margin-bottom:var(--sp-2)}.sort-header{border:none;background:none;font:inherit;color:inherit;cursor:pointer;padding:0;font-weight:600;display:inline-flex;align-items:center;gap:var(--sp-1);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em}.sort-header:hover{color:var(--c-accent)}dialog.detail-modal{padding:0;border:none;background:var(--c-surface);color:var(--c-text);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:min(720px,90vw);max-width:min(720px,90vw);max-height:80vh;display:none;grid-template-rows:auto 1fr;overflow:hidden}dialog.detail-modal[open]{display:grid}dialog.detail-modal.modal--wide{width:min(960px,90vw);max-width:min(960px,90vw)}dialog.detail-modal.modal--xwide{width:min(1200px,95vw);max-width:min(1200px,95vw)}dialog.detail-modal::backdrop{background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-backdrop{position:fixed;inset:0;background:#0006;z-index:var(--z-modal);display:flex;align-items:flex-start;justify-content:center;padding:var(--sp-10) var(--sp-4);overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}body:has(.modal-backdrop){overflow:hidden}.modal{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:min(720px,90vw);max-height:80vh;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.modal--wide{width:min(960px,90vw)}.modal--xwide{width:min(1200px,95vw);max-width:min(1200px,95vw)}.modal__header{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--c-border);min-width:0}.modal__header h2{margin:0;font-size:var(--text-lg);font-weight:600;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal__header-actions{display:flex;align-items:center;gap:var(--sp-2);flex:0 0 auto}.modal__close{border:none;background:none;font-size:var(--text-lg);cursor:pointer;color:var(--c-text-muted);padding:var(--sp-1);border-radius:var(--r-sm)}.modal__close:hover{background:var(--c-hover);color:var(--c-text)}.modal__body{padding:var(--sp-6);overflow-y:auto}.form-group{display:grid;gap:var(--sp-4);margin-bottom:var(--sp-5)}.form-group label{display:grid;gap:var(--sp-1);font-size:var(--text-sm);font-weight:500;color:var(--c-text)}.form-group input,.form-group select,.form-group textarea{padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--text-sm);background:var(--c-surface);color:var(--c-text);transition:border-color var(--duration-fast) var(--easing-standard),box-shadow var(--duration-fast) var(--easing-standard)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--c-border-strong)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--c-accent);box-shadow:0 0 0 2px #2563eb33;outline:none}.form-group--error input,.form-group--error select,.form-group--error textarea,.field-input--error{border-color:var(--c-error)}.form-group--error input:focus,.form-group--error select:focus,.form-group--error textarea:focus,.field-input--error:focus{border-color:var(--c-error);box-shadow:0 0 0 2px #dc26262e}.field-helper{display:block;margin-top:var(--sp-1);font-size:var(--text-xs);color:var(--c-text-muted);line-height:1.4}.field-helper--error{color:var(--c-error)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-3) 0;font-size:var(--text-xs);color:var(--c-text-muted)}.pagination .btn-group{gap:var(--sp-2)}@media(max-width:768px){.app-layout{grid-template-columns:1fr}.sidebar{width:100%;min-width:0;flex-direction:row;border-right:none;border-bottom:1px solid var(--c-border)}.sidebar__nav{flex-direction:row;padding:var(--sp-2);gap:0;flex-wrap:wrap}.sidebar__footer{display:none}.main{grid-column:1;padding:var(--sp-4)}.hero-actions,.grid--2col,.grid--3col{grid-template-columns:1fr}}.cmd-backdrop{position:fixed;inset:0;background:#0006;z-index:300;display:flex;justify-content:center;padding-top:15vh;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.cmd-palette{width:min(560px,90vw);background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slide-up .15s ease-out}.cmd-input-wrap{display:flex;align-items:center;padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--c-border);gap:var(--sp-3)}.cmd-input{flex:1;border:none;background:none;font-size:var(--text-md);color:var(--c-text);outline:none}.cmd-input::placeholder{color:var(--c-text-muted)}.cmd-kbd{font-size:var(--text-xs);padding:2px 6px;border-radius:var(--r-sm);background:var(--c-subtle);border:1px solid var(--c-border);color:var(--c-text-muted);font-family:var(--font-mono)}.cmd-results{max-height:360px;overflow-y:auto}.cmd-result{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:var(--sp-3) var(--sp-5);border:none;background:none;text-align:left;cursor:pointer;transition:background .08s}.cmd-result:hover,.cmd-result--active{background:var(--c-hover)}.cmd-kind{display:flex;align-items:center;justify-content:center;width:32px;height:24px;border-radius:var(--r-sm);font-size:.625rem;font-weight:700;letter-spacing:.04em;flex-shrink:0}.cmd-kind--api{background:#dbeafe;color:#1e40af}.cmd-kind--template{background:#e0e7ff;color:#3730a3}.cmd-kind--group{background:#d1fae5;color:#065f46}.cmd-kind--action{background:var(--c-subtle);color:var(--c-text-secondary)}.cmd-result__text{display:grid;gap:1px;min-width:0}.cmd-result__text strong{font-size:var(--text-sm);font-weight:500;color:var(--c-text)}.cmd-result__text small{font-size:var(--text-xs);color:var(--c-text-muted)}.cmd-empty{padding:var(--sp-8) var(--sp-5);text-align:center;color:var(--c-text-muted);font-size:var(--text-sm)}.wizard-steps{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-8)}.wizard-step{flex:1;padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);background:var(--c-subtle);border:1px solid var(--c-border);font-size:var(--text-sm);font-weight:500;color:var(--c-text-secondary);text-align:center;cursor:pointer;transition:all .15s}.wizard-step:hover{border-color:var(--c-border-strong)}.wizard-step--active{background:var(--c-accent);border-color:var(--c-accent);color:#fff;font-weight:600}.wizard-step--done{background:var(--c-success-bg);border-color:#a7f3d0;color:var(--c-success)}.searchable-select{position:relative;display:inline-block;min-width:220px}.searchable-select__trigger{width:100%;height:var(--control-h-md);padding:0 var(--sp-3);line-height:1;border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-surface);color:var(--c-text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);font-weight:var(--font-weight-normal);text-align:left;gap:var(--sp-2)}.searchable-select__trigger--sm{height:var(--control-h-sm);font-size:var(--text-xs)}.searchable-select__trigger--lg{height:var(--control-h-lg);font-size:var(--text-md);padding:0 var(--sp-4)}.searchable-select__trigger:hover:not(:disabled){border-color:var(--c-border-strong)}.searchable-select__trigger:disabled{opacity:.5;cursor:not-allowed;background:var(--c-subtle)}.searchable-select__trigger[aria-expanded=true]{border-color:var(--c-border-focus)}.searchable-select__label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-select__chevron{color:var(--c-text-muted);font-size:var(--text-xs)}.searchable-select__menu{position:absolute;left:0;right:0;z-index:var(--z-modal);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);max-height:320px;display:flex;flex-direction:column;min-width:220px}.searchable-select__menu--downward{top:100%;margin-top:4px}.searchable-select__menu--upward{bottom:100%;margin-bottom:4px}.searchable-select__search{height:var(--control-h-md);padding:0 var(--sp-3);border:0;border-bottom:1px solid var(--c-border);background:transparent;color:var(--c-text);font-size:var(--text-sm);outline:none;width:100%;box-sizing:border-box}.searchable-select__list{list-style:none;margin:0;padding:4px 0;overflow-y:auto;flex:1}.searchable-select__option{padding:var(--sp-2) var(--sp-3);cursor:pointer;display:flex;flex-direction:column;gap:2px;font-size:var(--text-sm)}.searchable-select__option:hover{background:var(--c-hover)}.searchable-select__option[aria-selected=true]{background:var(--c-accent-bg);color:var(--c-accent-dark)}.searchable-select__option[data-disabled=true]{opacity:.4;cursor:not-allowed}.searchable-select__option-label{font-weight:var(--font-weight-medium)}.searchable-select__option-description{font-size:var(--text-xs);color:var(--c-text-muted)}.searchable-select__empty{padding:12px;text-align:center;color:var(--c-text-muted);font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-normal{font-weight:var(--font-weight-normal)}.text-medium{font-weight:var(--font-weight-medium)}.text-semibold{font-weight:var(--font-weight-semibold)}.text-bold{font-weight:var(--font-weight-bold)}.text-right{text-align:right}.text-center{text-align:center}.text-left{text-align:left}.btn-icon-label{display:inline-flex;align-items:center;gap:4px}.btn-icon-label>svg{display:inline-block;flex-shrink:0}.data-table tbody tr:hover{background:var(--color-surface-2)}.data-table thead{position:sticky;top:0;background:var(--color-surface-1);z-index:1}.data-table thead th{border-bottom:1px solid var(--color-border-subtle);background:var(--color-surface-2);font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:var(--sp-2) var(--sp-3);text-align:left}.data-table tbody td{border-bottom:1px solid var(--color-border-subtle);padding:var(--sp-2) var(--sp-3)}.data-table tbody tr:last-child td{border-bottom:none}@keyframes skeleton-pulse{0%{opacity:.55}50%{opacity:1}to{opacity:.55}}.skeleton-block{display:block;background:var(--color-surface-2);border-radius:var(--radius-sm);height:1rem;width:100%;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-text-group{display:flex;flex-direction:column;gap:var(--sp-2)}.skeleton-text-line{height:12px}.skeleton-table{display:flex;flex-direction:column;gap:var(--sp-2);border:1px solid var(--color-border-subtle);border-radius:var(--r-md);padding:var(--sp-3);background:var(--color-surface-0)}.skeleton-table__row{display:grid;gap:var(--sp-3);align-items:center}.skeleton-table__cell{height:14px}.skeleton-card{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-4);border:1px solid var(--color-border-subtle);border-radius:var(--r-md);background:var(--color-surface-0);min-height:96px}.skeleton-card__title{height:12px;width:50%}.skeleton-card__value{height:24px;width:70%}.skeleton-card__note{height:10px;width:40%}.btn--sm{height:var(--control-h-sm);padding:0 var(--sp-3);font-size:var(--text-xs);font-weight:var(--font-weight-medium)}.btn--lg{height:var(--control-h-lg);padding:0 var(--sp-4);font-size:var(--text-md);border-radius:var(--r-lg)}.btn--icon{height:var(--control-h-md);width:var(--control-h-md);padding:0;border-radius:var(--radius-sm);background:transparent;border-color:transparent;color:var(--c-text-secondary)}.btn--icon:hover{background:var(--c-hover);border-color:var(--c-border);color:var(--c-text)}@keyframes btn-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-wrap{position:relative;display:inline-flex;align-items:stretch;width:100%}.input-wrap.filter-editor__half{width:50%}.input-wrap.flex-1{flex:1;min-width:0}.input-wrap.flex-2{flex:2;min-width:0}.input-wrap.allowed-fields-search{flex:1 1 12rem}.input-wrap.confirm-text-200{max-width:200px}.input-wrap>.input-leading-icon{position:absolute;left:var(--sp-2);top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;pointer-events:none;color:var(--c-text-muted)}.input-field{width:100%;height:var(--control-h-md);padding:0 var(--sp-3);line-height:1;border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--text-sm);font-family:inherit;background:var(--c-surface);color:var(--c-text);transition:border-color var(--motion-duration-quick) var(--motion-ease-standard),box-shadow var(--motion-duration-quick) var(--motion-ease-standard)}.input-field--sm{height:var(--control-h-sm);padding:0 var(--sp-3);font-size:var(--text-xs)}.input-field--lg{height:var(--control-h-lg);padding:0 var(--sp-4);font-size:var(--text-md)}.input-field:hover:not(:disabled){border-color:var(--c-border-strong)}.input-field:focus{border-color:var(--c-accent);box-shadow:0 0 0 2px #2563eb33;outline:none}.input-field:disabled{opacity:.6;cursor:not-allowed;background:var(--c-subtle)}.input-field--error,.input-field--error:focus{border-color:var(--c-error)}.input-field--error:focus{box-shadow:0 0 0 2px #dc26262e}.input-wrap--with-leading-icon>.input-field{padding-left:calc(var(--sp-2) + 1rem + var(--sp-2))}.input-wrap--with-leading-icon.input-wrap--sm>.input-field{padding-left:calc(var(--sp-2) + .875rem + var(--sp-2))}.input-wrap--with-leading-icon.input-wrap--lg>.input-field{padding-left:calc(var(--sp-3) + 1rem + var(--sp-3))}.input-helper{display:block;margin-top:var(--sp-1);font-size:var(--text-xs);color:var(--c-text-secondary)}.input-helper--error{color:var(--c-error)}.input-field--warning,.input-field--warning:hover:not(:disabled){border-color:var(--c-warning);background:var(--c-warning-bg)}.input-field--warning:focus{border-color:var(--c-warning);box-shadow:0 0 0 2px #d9770640;outline:none}.form-select-wrap{position:relative;display:inline-flex;align-items:stretch;width:100%}.form-select{appearance:none;-webkit-appearance:none;width:100%;height:var(--control-h-md);padding:0 calc(var(--sp-3) + 16px) 0 var(--sp-3);line-height:1;font-size:var(--text-sm);font-family:inherit;color:var(--c-text);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--motion-duration-quick) var(--motion-ease-standard),box-shadow var(--motion-duration-quick) var(--motion-ease-standard)}.form-select:hover:not(:disabled){border-color:var(--c-border-strong)}.form-select:focus,.form-select:focus-visible{border-color:var(--c-accent);box-shadow:0 0 0 2px #2563eb33;outline:none}.form-select:disabled{opacity:.6;cursor:not-allowed;background:var(--c-subtle)}.form-select--sm{height:var(--control-h-sm);font-size:var(--text-xs);padding:0 calc(var(--sp-3) + 16px) 0 var(--sp-3)}.form-select--lg{height:var(--control-h-lg);font-size:var(--text-md);padding:0 calc(var(--sp-4) + 16px) 0 var(--sp-4)}.form-select__chevron{position:absolute;right:var(--sp-3);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--c-text-secondary)}.multi-select{position:relative;display:inline-flex;flex-direction:column;width:100%}.multi-select__trigger{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:var(--sp-2);width:100%;height:var(--control-h-md);padding:0 var(--sp-3);font-size:var(--text-sm);font-family:inherit;color:var(--c-text);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);cursor:pointer;text-align:left;line-height:1;overflow:hidden;transition:border-color var(--motion-duration-quick) var(--motion-ease-standard),box-shadow var(--motion-duration-quick) var(--motion-ease-standard)}.multi-select__trigger:hover:not([data-disabled]){border-color:var(--c-border-strong)}.multi-select__trigger:focus,.multi-select__trigger:focus-visible{outline:none;border-color:var(--c-accent);box-shadow:var(--shadow-focus)}.multi-select__trigger[data-disabled]{opacity:.6;cursor:not-allowed;background:var(--c-subtle)}.multi-select__trigger--sm{height:var(--control-h-sm);font-size:var(--text-xs)}.multi-select__trigger--lg{height:var(--control-h-lg);font-size:var(--text-md);padding:0 var(--sp-4)}.multi-select__chips{display:inline-flex;align-items:center;gap:var(--sp-1);flex:1 1 auto;overflow:hidden;min-width:0}.multi-select__chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:2px var(--sp-2);background:var(--c-active);color:var(--c-text);border-radius:var(--r-sm);font-size:var(--text-xs);white-space:nowrap}.multi-select__chip-remove{background:transparent;border:0;padding:0;cursor:pointer;color:inherit;display:inline-flex;align-items:center}.multi-select__chip-remove:hover{color:var(--c-accent)}.multi-select__chip-overflow{font-size:var(--text-xs);color:var(--c-text-secondary);white-space:nowrap}.multi-select__chevron{margin-left:auto;pointer-events:none;color:var(--c-text-secondary);flex:0 0 auto}.multi-select__placeholder{color:var(--c-text-muted)}.multi-select__menu{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-height:280px;overflow-y:auto;z-index:50}.multi-select__option{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);cursor:pointer;font-size:var(--text-sm)}.multi-select__option:hover,.multi-select__option[data-active=true]{background:var(--c-active)}.multi-select__option[aria-selected=true]{color:var(--c-accent);font-weight:500}.multi-select__option[aria-disabled=true]{opacity:.6;cursor:not-allowed}.multi-select__option-check{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.multi-select__hidden-native{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.textarea-field{width:100%;min-height:calc(var(--control-h-md) * 2);padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);font-family:inherit;color:var(--c-text);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);line-height:1.4;resize:vertical;transition:border-color var(--motion-duration-quick) var(--motion-ease-standard),box-shadow var(--motion-duration-quick) var(--motion-ease-standard)}.textarea-field:hover:not(:disabled){border-color:var(--c-border-strong)}.textarea-field:focus,.textarea-field:focus-visible{border-color:var(--c-accent);box-shadow:0 0 0 2px #2563eb33;outline:none}.textarea-field:disabled{opacity:.6;cursor:not-allowed;background:var(--c-subtle)}.textarea-field--sm{font-size:var(--text-xs);padding:var(--sp-1) var(--sp-3);min-height:calc(var(--control-h-sm) * 2)}.textarea-field--lg{font-size:var(--text-md);padding:var(--sp-3) var(--sp-4);min-height:calc(var(--control-h-lg) * 2)}.textarea-field--error,.textarea-field--error:focus{border-color:var(--c-error)}.textarea-field--error:focus{box-shadow:0 0 0 2px #dc26262e}.form-field{display:flex;flex-direction:column;gap:var(--sp-1)}.form-field__label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--c-text)}.form-field__required{color:var(--c-error);margin-left:2px}.form-field__control{display:flex;flex-direction:column}.form-field__helper{font-size:var(--text-xs);color:var(--c-text-secondary)}.form-field__error{font-size:var(--text-xs);color:var(--c-error)}.card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-3)}.card__title{margin:0;font-size:var(--text-md);font-weight:var(--font-weight-semibold);color:var(--c-text);line-height:1.3}.card__actions{display:inline-flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.card__body{display:block}.app-shell{display:flex;flex-direction:column;height:100vh}.session-expired-banner{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-4);background:var(--c-warning-bg, #fffbeb);color:var(--c-warning, #d97706);border-bottom:1px solid var(--c-tag-warning-border, #fec84b);font-size:var(--text-sm);font-weight:500;z-index:100}.session-expired-banner>span{color:var(--c-text, #15314b)}.topbar{display:flex;align-items:center;gap:var(--sp-4);padding:0 var(--sp-5);height:var(--topbar-h);flex:0 0 var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border)}.topbar__brand{display:flex;align-items:center}.topbar__brand img{height:36px;width:auto;display:block}.topbar__grow{flex:1}.topbar__icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:var(--r-md);color:var(--c-text-secondary);cursor:pointer;transition:background var(--d-micro) var(--ease)}.topbar__icon-btn:hover{background:var(--c-subtle);color:var(--c-text)}.topbar__icon-btn:focus-visible{box-shadow:var(--shadow-focus);outline:none}.topbar__avatar{width:28px;height:28px;border-radius:var(--r-full);background:var(--grad-pyramid);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:0;cursor:pointer}.topbar__avatar:focus-visible{box-shadow:var(--shadow-focus);outline:none}.topbar__icon-wrap{position:relative;display:inline-flex;align-items:center}.topbar__dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-md, 0 8px 24px rgba(15, 23, 42, .12));padding:var(--sp-2);z-index:100}.topbar__dropdown--user{min-width:240px}.topbar__dropdown__row{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) var(--sp-3);border:0;background:transparent;border-radius:var(--r-md);cursor:pointer;font:inherit;font-size:13px;color:var(--c-text);text-align:left;text-decoration:none}.topbar__dropdown__row:hover,.topbar__dropdown__row:focus-visible{background:var(--c-subtle);outline:none}.topbar__dropdown__row>span{flex:1}.topbar__dropdown__hint{flex:0 0 auto;color:var(--c-text-muted);font-family:var(--font-mono);font-size:11px}.topbar__dropdown__divider{height:1px;background:var(--c-border);margin:var(--sp-1) 0}.topbar__dropdown__empty{padding:var(--sp-3) var(--sp-4);font-size:13px;color:var(--c-text-muted);text-align:center}.topbar__icon-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--c-danger, #dc2626);color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.topbar__dropdown--bell{width:360px;max-height:480px;overflow-y:auto}.topbar__dropdown__list{list-style:none;margin:0;padding:0}.topbar__dropdown__notification{width:100%;display:flex;align-items:flex-start;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:transparent;border:none;text-align:left;cursor:pointer;font:inherit;color:var(--c-text)}.topbar__dropdown__notification:hover{background:var(--c-surface-2, #f8fafc)}.topbar__dropdown__notification--unread{background:var(--c-surface-3, #f1f5f9)}.topbar__dropdown__notification-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.topbar__dropdown__notification-dot--info{background:#2563eb}.topbar__dropdown__notification-dot--warn{background:#d97706}.topbar__dropdown__notification-dot--error{background:#dc2626}.topbar__dropdown__notification-dot--success{background:#059669}.topbar__dropdown__notification-body{display:flex;flex-direction:column;gap:2px;min-width:0}.topbar__dropdown__notification-title{font-size:13px;font-weight:600;color:var(--c-text)}.topbar__dropdown__notification-sub{font-size:12px;color:var(--c-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar__dropdown__notification-time{font-size:11px;color:var(--c-text-muted)}.topbar__dropdown__footer{border-top:1px solid var(--c-border);padding:var(--sp-1) var(--sp-3);text-align:right}.topbar__dropdown__link{background:transparent;border:none;padding:var(--sp-1) var(--sp-2);font:inherit;font-size:12px;color:var(--c-link, #2563eb);cursor:pointer}.topbar__dropdown__user-head{padding:var(--sp-2) var(--sp-3);display:flex;flex-direction:column;gap:2px}.topbar__dropdown__user-email{font-size:13px;font-weight:600;color:var(--c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar__dropdown__user-role{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-muted)}.topbar__shortcuts-backdrop{position:fixed;inset:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:200}.topbar__shortcuts{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg, 0 20px 40px rgba(15, 23, 42, .2));width:420px;max-width:calc(100vw - 32px);padding:var(--sp-5)}.topbar__shortcuts__head h2{margin:0 0 var(--sp-3);font-size:16px;font-weight:600;color:var(--c-text)}.topbar__shortcuts__list{margin:0;padding:0}.topbar__shortcuts__row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) 0;border-bottom:1px solid var(--c-border)}.topbar__shortcuts__row:last-child{border-bottom:0}.topbar__shortcuts__row dt{flex:0 0 100px;font-size:12px;color:var(--c-text-secondary)}.topbar__shortcuts__row dd{margin:0;font-size:13px;color:var(--c-text)}.topbar__shortcuts kbd{display:inline-block;padding:1px 6px;border:1px solid var(--c-border);border-radius:var(--r-sm, 4px);background:var(--c-subtle);font-family:var(--font-mono);font-size:11px;color:var(--c-text)}.global-search{position:relative}.global-search__input{display:flex;align-items:center;gap:var(--sp-2);background:var(--c-subtle);border:1px solid var(--c-border);border-radius:var(--r-md);padding:6px 10px;min-width:320px;color:var(--c-text-muted);font-size:var(--text-sm);cursor:text}.global-search__input input{flex:1;border:0;background:transparent;outline:none;font:inherit;color:var(--c-text);padding:0}.global-search__input input::placeholder{color:var(--c-text-muted)}.global-search__input:focus-within{background:var(--c-surface);box-shadow:var(--shadow-focus);border-color:var(--c-border-focus)}.global-search__input kbd{font-family:var(--font-mono);font-size:11px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:3px;padding:0 5px;color:var(--c-text-secondary)}.global-search__dropdown{position:absolute;top:calc(100% + var(--sp-1));left:0;right:0;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-height:480px;overflow-y:auto;z-index:var(--z-modal);padding:var(--sp-2) 0}.global-search__group+.global-search__group{border-top:1px solid var(--c-border);margin-top:var(--sp-2);padding-top:var(--sp-2)}.global-search__group-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-muted);padding:var(--sp-1) var(--sp-3)}.global-search__item{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:6px var(--sp-3);background:transparent;border:0;cursor:pointer;font:inherit;color:var(--c-text);text-align:left}.global-search__item.is-highlighted{background:var(--c-accent-bg);color:var(--c-accent)}.global-search__item-label{flex:1}.global-search__item-meta{font-size:11px;color:var(--c-text-muted)}.global-search__empty{padding:var(--sp-3);font-size:var(--text-sm);color:var(--c-text-muted);text-align:center}
