:root,[data-density=normal]{--so-space-1: 4px;--so-space-2: 8px;--so-space-3: 12px;--so-space-4: 16px;--so-space-5: 24px;--so-space-6: 32px;--so-control-height-sm: 28px;--so-control-height-md: 36px;--so-control-height-lg: 44px;--so-font-size-sm: 12px;--so-font-size-md: 14px;--so-font-size-lg: 16px;--so-line-height: 1.5;--so-radius: 6px;--so-disabled-opacity: .5}[data-density=dense]{--so-space-1: 2px;--so-space-2: 4px;--so-space-3: 8px;--so-space-4: 12px;--so-space-5: 16px;--so-space-6: 24px;--so-control-height-sm: 24px;--so-control-height-md: 28px;--so-control-height-lg: 36px;--so-font-size-sm: 11px;--so-font-size-md: 12px;--so-font-size-lg: 14px;--so-radius: 4px}:root{--so-color-primary-base: #3b82f6;--so-color-primary-fg: #ffffff;--so-color-primary-subtle: #eff6ff;--so-color-primary-subtle-fg: #1e40af;--so-color-primary-border: #93c5fd;--so-color-primary-hover: #2563eb;--so-color-primary-active: #1d4ed8;--so-color-neutral-base: #6b7280;--so-color-neutral-fg: #ffffff;--so-color-neutral-subtle: #f3f4f6;--so-color-neutral-subtle-fg: #374151;--so-color-neutral-border: #d1d5db;--so-color-neutral-hover: #4b5563;--so-color-neutral-active: #374151;--so-color-danger-base: #ef4444;--so-color-danger-fg: #ffffff;--so-color-danger-subtle: #fef2f2;--so-color-danger-subtle-fg: #991b1b;--so-color-danger-border: #fca5a5;--so-color-danger-hover: #dc2626;--so-color-danger-active: #b91c1c;--so-color-success-base: #22c55e;--so-color-success-fg: #ffffff;--so-color-success-subtle: #f0fdf4;--so-color-success-subtle-fg: #166534;--so-color-success-border: #86efac;--so-color-success-hover: #16a34a;--so-color-success-active: #15803d;--so-color-warning-base: #f59e0b;--so-color-warning-fg: #ffffff;--so-color-warning-subtle: #fffbeb;--so-color-warning-subtle-fg: #92400e;--so-color-warning-border: #fcd34d;--so-color-warning-hover: #d97706;--so-color-warning-active: #b45309;--so-color-info-base: #06b6d4;--so-color-info-fg: #ffffff;--so-color-info-subtle: #ecfeff;--so-color-info-subtle-fg: #155e75;--so-color-info-border: #67e8f9;--so-color-info-hover: #0891b2;--so-color-info-active: #0e7490;--so-bg: #ffffff;--so-bg-subtle: #f8f9fa;--so-text: #111827;--so-text-muted: #6b7280;--so-border: #e5e7eb;--so-ring: var(--so-color-primary-base)}[data-theme=dark]{--so-color-primary-base: #3b82f6;--so-color-primary-fg: #ffffff;--so-color-primary-subtle: #172554;--so-color-primary-subtle-fg: #93c5fd;--so-color-primary-border: #1d4ed8;--so-color-primary-hover: #2563eb;--so-color-primary-active: #1d4ed8;--so-color-neutral-base: #4b5563;--so-color-neutral-fg: #ffffff;--so-color-neutral-subtle: #1f2937;--so-color-neutral-subtle-fg: #d1d5db;--so-color-neutral-border: #374151;--so-color-neutral-hover: #374151;--so-color-neutral-active: #1f2937;--so-color-danger-base: #dc2626;--so-color-danger-fg: #ffffff;--so-color-danger-subtle: #450a0a;--so-color-danger-subtle-fg: #fca5a5;--so-color-danger-border: #991b1b;--so-color-danger-hover: #b91c1c;--so-color-danger-active: #991b1b;--so-color-success-base: #16a34a;--so-color-success-fg: #ffffff;--so-color-success-subtle: #052e16;--so-color-success-subtle-fg: #86efac;--so-color-success-border: #15803d;--so-color-success-hover: #15803d;--so-color-success-active: #166534;--so-color-warning-base: #d97706;--so-color-warning-fg: #ffffff;--so-color-warning-subtle: #451a03;--so-color-warning-subtle-fg: #fcd34d;--so-color-warning-border: #b45309;--so-color-warning-hover: #b45309;--so-color-warning-active: #92400e;--so-color-info-base: #0891b2;--so-color-info-fg: #ffffff;--so-color-info-subtle: #083344;--so-color-info-subtle-fg: #67e8f9;--so-color-info-border: #0e7490;--so-color-info-hover: #0e7490;--so-color-info-active: #155e75;--so-bg: #0f172a;--so-bg-subtle: #1e293b;--so-text: #f1f5f9;--so-text-muted: #94a3b8;--so-border: #334155;--so-ring: var(--so-color-primary-base)}body{background-color:var(--so-bg);color:var(--so-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:var(--so-line-height)}:focus-visible{outline:2px solid var(--so-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.so-accordion{display:flex;flex-direction:column;border:1px solid var(--so-border);border-radius:var(--so-radius);overflow:hidden}.so-accordion-item{border-bottom:1px solid var(--so-border)}.so-accordion-item:last-child{border-bottom:none}.so-accordion-item__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--so-space-3) var(--so-space-4);background:none;border:none;font:inherit;font-size:var(--so-font-size-md);font-weight:500;color:var(--so-text);cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;transition:background-color .15s}.so-accordion-item__trigger::-webkit-details-marker{display:none}.so-accordion-item__trigger::marker{display:none;content:""}.so-accordion-item__trigger:hover{background-color:var(--so-color-neutral-subtle)}.so-accordion-item__trigger:focus-visible{outline:2px solid var(--so-ring);outline-offset:-2px}.so-accordion-item__chevron{width:16px;height:16px;flex-shrink:0;transition:transform .2s;color:var(--so-text-muted)}.so-accordion-item[open]>.so-accordion-item__trigger .so-accordion-item__chevron{transform:rotate(180deg)}.so-accordion-item__content{padding:0 var(--so-space-4) var(--so-space-4);color:var(--so-text);font-size:var(--so-font-size-md);line-height:var(--so-line-height)}.so-accordion-item--disabled{opacity:var(--so-disabled-opacity)}.so-accordion-item--disabled>.so-accordion-item__trigger{cursor:not-allowed}.so-alert{display:flex;align-items:flex-start;gap:var(--so-space-3);padding:var(--so-space-3) var(--so-space-4);border:1px solid transparent;border-radius:var(--so-radius);font-size:var(--so-font-size-md);line-height:var(--so-line-height)}.so-alert__content{flex:1}.so-alert__dismiss{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:none;font-size:18px;line-height:1;cursor:pointer;border-radius:var(--so-radius);opacity:.7;color:inherit}.so-alert__dismiss:hover{opacity:1}.so-alert--info{background-color:var(--so-color-info-subtle);color:var(--so-color-info-subtle-fg);border-color:var(--so-color-info-border)}.so-alert--success{background-color:var(--so-color-success-subtle);color:var(--so-color-success-subtle-fg);border-color:var(--so-color-success-border)}.so-alert--warning{background-color:var(--so-color-warning-subtle);color:var(--so-color-warning-subtle-fg);border-color:var(--so-color-warning-border)}.so-alert--danger{background-color:var(--so-color-danger-subtle);color:var(--so-color-danger-subtle-fg);border-color:var(--so-color-danger-border)}.so-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;font-weight:600;-webkit-user-select:none;user-select:none}.so-avatar__img{width:100%;height:100%;object-fit:cover}.so-avatar__initials{line-height:1}.so-avatar__fallback{width:60%;height:60%}.so-avatar--sm{width:28px;height:28px;font-size:var(--so-font-size-xs, 10px)}.so-avatar--md{width:36px;height:36px;font-size:var(--so-font-size-sm)}.so-avatar--lg{width:48px;height:48px;font-size:var(--so-font-size-md)}.so-avatar--primary{background-color:var(--so-color-primary-subtle);color:var(--so-color-primary-base)}.so-avatar--neutral{background-color:var(--so-color-neutral-subtle);color:var(--so-text-muted)}.so-avatar--success{background-color:var(--so-color-success-subtle);color:var(--so-color-success-base)}.so-avatar--danger{background-color:var(--so-color-danger-subtle);color:var(--so-color-danger-base)}.so-avatar--warning{background-color:var(--so-color-warning-subtle);color:var(--so-color-warning-base)}.so-avatar--info{background-color:var(--so-color-info-subtle);color:var(--so-color-info-base)}.so-badge{display:inline-flex;align-items:center;border-radius:var(--so-radius);font-weight:500;line-height:1;white-space:nowrap}.so-badge--sm{padding:var(--so-space-1) var(--so-space-2);font-size:var(--so-font-size-sm)}.so-badge--md{padding:var(--so-space-1) var(--so-space-3);font-size:var(--so-font-size-md)}.so-badge--primary{background-color:var(--so-color-primary-subtle);color:var(--so-color-primary-subtle-fg)}.so-badge--neutral{background-color:var(--so-color-neutral-subtle);color:var(--so-color-neutral-subtle-fg)}.so-badge--danger{background-color:var(--so-color-danger-subtle);color:var(--so-color-danger-subtle-fg)}.so-badge--success{background-color:var(--so-color-success-subtle);color:var(--so-color-success-subtle-fg)}.so-badge--warning{background-color:var(--so-color-warning-subtle);color:var(--so-color-warning-subtle-fg)}.so-badge--info{background-color:var(--so-color-info-subtle);color:var(--so-color-info-subtle-fg)}.so-badge--solid.so-badge--primary{background-color:var(--so-color-primary-base);color:var(--so-color-primary-fg)}.so-badge--solid.so-badge--neutral{background-color:var(--so-color-neutral-base);color:var(--so-color-neutral-fg)}.so-badge--solid.so-badge--danger{background-color:var(--so-color-danger-base);color:var(--so-color-danger-fg)}.so-badge--solid.so-badge--success{background-color:var(--so-color-success-base);color:var(--so-color-success-fg)}.so-badge--solid.so-badge--warning{background-color:var(--so-color-warning-base);color:var(--so-color-warning-fg)}.so-badge--solid.so-badge--info{background-color:var(--so-color-info-base);color:var(--so-color-info-fg)}.so-breadcrumb__list{display:flex;align-items:center;list-style:none;margin:0;padding:0;gap:0;font-size:var(--so-font-size-md)}.so-breadcrumb__item{display:inline-flex;align-items:center;color:var(--so-text-muted)}.so-breadcrumb__item+.so-breadcrumb__item:before{content:"/";margin:0 var(--so-space-2);color:var(--so-text-muted);opacity:.5}.so-breadcrumb__item a{color:var(--so-color-primary-base);text-decoration:none}.so-breadcrumb__item a:hover{text-decoration:underline}.so-breadcrumb__item a:focus-visible{outline:2px solid var(--so-ring);outline-offset:2px;border-radius:2px}.so-breadcrumb__item--current{color:var(--so-text);font-weight:500}.so-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--so-space-2);border:1px solid transparent;border-radius:var(--so-radius);font-family:inherit;font-weight:500;line-height:var(--so-line-height);cursor:pointer;transition:background-color .15s,border-color .15s,color .15s;white-space:nowrap;-webkit-user-select:none;user-select:none}.so-button:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-button--sm{height:var(--so-control-height-sm);padding:0 var(--so-space-3);font-size:var(--so-font-size-sm)}.so-button--md{height:var(--so-control-height-md);padding:0 var(--so-space-4);font-size:var(--so-font-size-md)}.so-button--lg{height:var(--so-control-height-lg);padding:0 var(--so-space-5);font-size:var(--so-font-size-lg)}.so-button--primary{background-color:var(--so-color-primary-base);color:var(--so-color-primary-fg)}.so-button--primary:hover:not(:disabled){background-color:var(--so-color-primary-hover)}.so-button--primary:active:not(:disabled){background-color:var(--so-color-primary-active)}.so-button--neutral{background-color:transparent;color:var(--so-text);border-color:var(--so-color-neutral-border)}.so-button--neutral:hover:not(:disabled){background-color:var(--so-color-neutral-subtle)}.so-button--neutral:active:not(:disabled){background-color:var(--so-color-neutral-border)}.so-button--danger{background-color:var(--so-color-danger-base);color:var(--so-color-danger-fg)}.so-button--danger:hover:not(:disabled){background-color:var(--so-color-danger-hover)}.so-button--danger:active:not(:disabled){background-color:var(--so-color-danger-active)}.so-button--ghost{background-color:transparent;color:var(--so-text)}.so-button--ghost:hover:not(:disabled){background-color:var(--so-color-neutral-subtle)}.so-button--ghost:active:not(:disabled){background-color:var(--so-color-neutral-border)}.so-button--loading{position:relative;color:transparent;pointer-events:none}.so-button__spinner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.so-button__spinner:after{content:"";width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:so-button-spin .6s linear infinite}@keyframes so-button-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.so-button__spinner:after{animation:none}}.so-button--loading.so-button--primary .so-button__spinner,.so-button--loading.so-button--danger .so-button__spinner{color:var(--so-color-primary-fg)}.so-button--loading.so-button--neutral .so-button__spinner,.so-button--loading.so-button--ghost .so-button__spinner{color:var(--so-text)}.so-button__icon{display:inline-flex;align-items:center;flex-shrink:0}.so-card{background-color:var(--so-bg);border:1px solid var(--so-border);border-radius:var(--so-radius);overflow:hidden}.so-card--elevated{border-color:transparent;box-shadow:0 1px 3px #0000001a,0 4px 16px #0000000f}.so-card__header{padding:var(--so-space-4) var(--so-space-5);border-bottom:1px solid var(--so-border);font-weight:600;font-size:var(--so-font-size-lg);color:var(--so-text)}.so-card__body{padding:var(--so-space-4) var(--so-space-5);color:var(--so-text)}.so-card__footer{padding:var(--so-space-3) var(--so-space-5);border-top:1px solid var(--so-border);background-color:var(--so-bg-subtle)}.so-checkbox{display:inline-flex;align-items:center;gap:var(--so-space-2);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:var(--so-line-height)}.so-checkbox--disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-checkbox__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.so-checkbox__indicator{display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--so-border);border-radius:calc(var(--so-radius) / 2);background-color:var(--so-bg);color:var(--so-color-primary-fg);flex-shrink:0;transition:background-color .15s,border-color .15s}.so-checkbox__input:checked+.so-checkbox__indicator,.so-checkbox__input:indeterminate+.so-checkbox__indicator{background-color:var(--so-color-primary-base);border-color:var(--so-color-primary-base)}.so-checkbox__input:focus-visible+.so-checkbox__indicator{outline:2px solid var(--so-ring);outline-offset:2px}.so-checkbox__icon{width:100%;height:100%}.so-checkbox__label{color:var(--so-text)}.so-checkbox--sm .so-checkbox__indicator{width:14px;height:14px}.so-checkbox--sm .so-checkbox__label{font-size:var(--so-font-size-sm)}.so-checkbox--md .so-checkbox__indicator{width:18px;height:18px}.so-checkbox--md .so-checkbox__label{font-size:var(--so-font-size-md)}.so-checkbox-wrapper--error .so-checkbox__indicator{border-color:var(--so-color-danger-base)}.so-checkbox__error{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-color-danger-base)}.so-checkbox__hint{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-text-muted)}.so-checkbox-group{border:none;padding:0;margin:0}.so-checkbox-group__label{font-size:var(--so-font-size-sm);font-weight:500;color:var(--so-text);line-height:var(--so-line-height);margin-bottom:var(--so-space-2)}.so-checkbox-group__items{display:flex;flex-direction:column;gap:var(--so-space-2)}.so-checkbox-group__error{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-color-danger-base)}.so-checkbox-group__hint{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-text-muted)}.so-description-list{margin:0;padding:0;color:var(--so-text)}.so-description-list__term{font-weight:600;font-size:var(--so-font-size-sm);color:var(--so-text-muted);margin-bottom:var(--so-space-1)}.so-description-list__detail{margin:0 0 var(--so-space-4) 0;font-size:var(--so-font-size-md)}.so-description-list--2col{display:grid;grid-template-columns:1fr 1fr;gap:0 var(--so-space-6)}.so-description-list--2col .so-description-list__detail{margin-bottom:var(--so-space-4)}.so-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#00000080;z-index:1000;animation:so-dialog-backdrop-in .2s ease-out}.so-dialog-backdrop--closing{animation:so-dialog-backdrop-out .15s ease-in forwards}.so-dialog{background-color:var(--so-bg);border:1px solid var(--so-border);border-radius:var(--so-radius);box-shadow:0 8px 32px #0003;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:so-dialog-in .2s ease-out}.so-dialog--closing{animation:so-dialog-out .15s ease-in forwards}.so-dialog--sm{width:400px;max-width:90vw}.so-dialog--md{width:560px;max-width:90vw}.so-dialog--lg{width:720px;max-width:90vw}.so-dialog__header{padding:var(--so-space-4) var(--so-space-5);border-bottom:1px solid var(--so-border);font-weight:600;font-size:var(--so-font-size-lg);color:var(--so-text);flex-shrink:0}.so-dialog__body{padding:var(--so-space-4) var(--so-space-5);overflow-y:auto;flex:1;color:var(--so-text)}.so-dialog__footer{padding:var(--so-space-3) var(--so-space-5);border-top:1px solid var(--so-border);display:flex;justify-content:flex-end;gap:var(--so-space-2);flex-shrink:0}@keyframes so-dialog-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes so-dialog-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes so-dialog-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes so-dialog-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@media(prefers-reduced-motion:reduce){.so-dialog-backdrop,.so-dialog-backdrop--closing,.so-dialog,.so-dialog--closing{animation:none}}.so-divider{border:none;margin:0}.so-divider--horizontal{width:100%;height:1px;background-color:var(--so-border)}.so-divider--vertical{width:1px;align-self:stretch;background-color:var(--so-border)}.so-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:1000;animation:so-drawer-backdrop-in .2s ease-out}.so-drawer-backdrop--closing{animation:so-drawer-backdrop-out .2s ease-in forwards}.so-drawer{position:fixed;top:0;bottom:0;background-color:var(--so-bg);border:1px solid var(--so-border);box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;overflow-y:auto}.so-drawer--left{left:0;animation:so-drawer-slide-in-left .25s ease-out}.so-drawer--left.so-drawer--closing{animation:so-drawer-slide-out-left .2s ease-in forwards}.so-drawer--right{right:0;animation:so-drawer-slide-in-right .25s ease-out}.so-drawer--right.so-drawer--closing{animation:so-drawer-slide-out-right .2s ease-in forwards}.so-drawer--sm{width:280px;max-width:80vw}.so-drawer--md{width:400px;max-width:80vw}.so-drawer--lg{width:560px;max-width:80vw}.so-drawer__header{padding:var(--so-space-4);font-size:var(--so-font-size-lg);font-weight:600;color:var(--so-text);border-bottom:1px solid var(--so-border)}@keyframes so-drawer-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes so-drawer-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes so-drawer-slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes so-drawer-slide-out-right{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes so-drawer-slide-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes so-drawer-slide-out-left{0%{transform:translate(0)}to{transform:translate(-100%)}}@media(prefers-reduced-motion:reduce){.so-drawer-backdrop,.so-drawer-backdrop--closing,.so-drawer,.so-drawer--closing{animation:none}}.so-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--so-space-6);text-align:center}.so-empty-state__icon{margin-bottom:var(--so-space-4);color:var(--so-text-muted);font-size:48px;line-height:1}.so-empty-state__title{margin:0 0 var(--so-space-2) 0;font-size:var(--so-font-size-lg);font-weight:600;color:var(--so-text)}.so-empty-state__description{margin:0 0 var(--so-space-4) 0;font-size:var(--so-font-size-md);color:var(--so-text-muted);max-width:360px}.so-empty-state__action{margin-top:var(--so-space-2)}.so-form-field{display:flex;flex-direction:column;gap:var(--so-space-1)}.so-form-field__label{font-size:var(--so-font-size-sm);font-weight:500;color:var(--so-text);line-height:var(--so-line-height)}.so-form-field__required{color:var(--so-color-danger-base);margin-left:var(--so-space-1)}.so-form-field__hint{font-size:var(--so-font-size-sm);color:var(--so-text-muted);margin:0;line-height:var(--so-line-height)}.so-form-field__error{font-size:var(--so-font-size-sm);color:var(--so-color-danger-base);margin:0;line-height:var(--so-line-height)}.so-hstack{display:flex;flex-direction:row}.so-hstack--wrap{flex-wrap:wrap}.so-hstack--gap-1{gap:var(--so-space-1)}.so-hstack--gap-2{gap:var(--so-space-2)}.so-hstack--gap-3{gap:var(--so-space-3)}.so-hstack--gap-4{gap:var(--so-space-4)}.so-hstack--gap-5{gap:var(--so-space-5)}.so-hstack--gap-6{gap:var(--so-space-6)}.so-hstack--align-start{align-items:flex-start}.so-hstack--align-center{align-items:center}.so-hstack--align-end{align-items:flex-end}.so-hstack--align-stretch{align-items:stretch}.so-hstack--justify-start{justify-content:flex-start}.so-hstack--justify-center{justify-content:center}.so-hstack--justify-end{justify-content:flex-end}.so-hstack--justify-between{justify-content:space-between}.so-hstack--justify-around{justify-content:space-around}.so-icon-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--so-radius);font-family:inherit;cursor:pointer;transition:background-color .15s,border-color .15s,color .15s;-webkit-user-select:none;user-select:none;padding:0}.so-icon-button:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-icon-button--sm{width:var(--so-control-height-sm);height:var(--so-control-height-sm);font-size:var(--so-font-size-sm)}.so-icon-button--md{width:var(--so-control-height-md);height:var(--so-control-height-md);font-size:var(--so-font-size-md)}.so-icon-button--lg{width:var(--so-control-height-lg);height:var(--so-control-height-lg);font-size:var(--so-font-size-lg)}.so-icon-button--primary{background-color:var(--so-color-primary-base);color:var(--so-color-primary-fg)}.so-icon-button--primary:hover:not(:disabled){background-color:var(--so-color-primary-hover)}.so-icon-button--primary:active:not(:disabled){background-color:var(--so-color-primary-active)}.so-icon-button--neutral{background-color:transparent;color:var(--so-text);border-color:var(--so-color-neutral-border)}.so-icon-button--neutral:hover:not(:disabled){background-color:var(--so-color-neutral-subtle)}.so-icon-button--neutral:active:not(:disabled){background-color:var(--so-color-neutral-border)}.so-icon-button--danger{background-color:var(--so-color-danger-base);color:var(--so-color-danger-fg)}.so-icon-button--danger:hover:not(:disabled){background-color:var(--so-color-danger-hover)}.so-icon-button--danger:active:not(:disabled){background-color:var(--so-color-danger-active)}.so-icon-button--ghost{background-color:transparent;color:var(--so-text)}.so-icon-button--ghost:hover:not(:disabled){background-color:var(--so-color-neutral-subtle)}.so-icon-button--ghost:active:not(:disabled){background-color:var(--so-color-neutral-border)}.so-menu-anchor{display:inline-flex;position:relative}.so-menu-trigger{display:inline-flex;align-items:center;background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer}.so-menu{position:absolute;z-index:1000;background-color:var(--so-bg);border:1px solid var(--so-border);border-radius:var(--so-radius);box-shadow:0 4px 16px #0000001f;padding:var(--so-space-1) 0;min-width:160px;animation:so-menu-in .15s ease-out}@keyframes so-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.so-menu-item{display:flex;align-items:center;padding:var(--so-space-2) var(--so-space-3);font-size:var(--so-font-size-md);color:var(--so-text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .1s;outline:none}.so-menu-item:hover,.so-menu-item:focus-visible{background-color:var(--so-color-neutral-subtle)}.so-menu-item--disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-menu-item--disabled:hover,.so-menu-item--disabled:focus-visible{background-color:transparent}@media(prefers-reduced-motion:reduce){.so-menu{animation:none}}.so-menu-separator{height:1px;background-color:var(--so-border);margin:var(--so-space-1) 0}.so-number-input{display:inline-flex;align-items:center;border:1px solid var(--so-border);border-radius:var(--so-radius);background-color:var(--so-bg);overflow:hidden;transition:border-color .15s,box-shadow .15s;width:100%}.so-number-input:focus-within{outline:2px solid var(--so-ring);outline-offset:-1px;border-color:transparent}.so-number-input:has([aria-invalid=true]){border-color:var(--so-color-danger-base)}.so-number-input:has([aria-invalid=true]):focus-within{outline-color:var(--so-color-danger-base);border-color:transparent}.so-number-input__input{flex:1;min-width:0;border:none;background:transparent;color:var(--so-text);font-family:inherit;text-align:center;line-height:var(--so-line-height);-moz-appearance:textfield;box-sizing:border-box}.so-number-input__input::-webkit-inner-spin-button,.so-number-input__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.so-number-input__input:focus{outline:none}.so-number-input__input:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-number-input__button{display:inline-flex;align-items:center;justify-content:center;border:none;background-color:var(--so-color-neutral-subtle);color:var(--so-text);font-family:inherit;font-weight:600;cursor:pointer;flex-shrink:0;-webkit-user-select:none;user-select:none;transition:background-color .15s}.so-number-input__button:hover:not(:disabled){background-color:var(--so-color-neutral-border)}.so-number-input__button:active:not(:disabled){background-color:var(--so-color-neutral-active);color:var(--so-color-neutral-fg)}.so-number-input__button:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-number-input--sm{height:var(--so-control-height-sm)}.so-number-input--sm .so-number-input__input{font-size:var(--so-font-size-sm)}.so-number-input--sm .so-number-input__button{width:var(--so-control-height-sm);font-size:var(--so-font-size-sm)}.so-number-input--md{height:var(--so-control-height-md)}.so-number-input--md .so-number-input__input{font-size:var(--so-font-size-md)}.so-number-input--md .so-number-input__button{width:var(--so-control-height-md);font-size:var(--so-font-size-md)}.so-number-input--lg{height:var(--so-control-height-lg)}.so-number-input--lg .so-number-input__input{font-size:var(--so-font-size-lg)}.so-number-input--lg .so-number-input__button{width:var(--so-control-height-lg);font-size:var(--so-font-size-lg)}.so-pagination{display:inline-flex;align-items:center;gap:var(--so-space-2)}.so-pagination__button{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--so-color-neutral-border);border-radius:var(--so-radius);background:transparent;color:var(--so-text);font:inherit;cursor:pointer;transition:background-color .15s;white-space:nowrap}.so-pagination__button:hover:not(:disabled){background-color:var(--so-color-neutral-subtle)}.so-pagination__button:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-pagination__info{font-size:var(--so-font-size-md);color:var(--so-text);min-width:60px;text-align:center}.so-pagination--sm .so-pagination__button{height:var(--so-control-height-sm);padding:0 var(--so-space-3);font-size:var(--so-font-size-sm)}.so-pagination--sm .so-pagination__info{font-size:var(--so-font-size-sm)}.so-pagination--md .so-pagination__button{height:var(--so-control-height-md);padding:0 var(--so-space-4);font-size:var(--so-font-size-md)}.so-pagination__page{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--so-radius);background:transparent;color:var(--so-text);font:inherit;cursor:pointer;transition:background-color .15s;min-width:2em}.so-pagination__page:hover{background-color:var(--so-color-neutral-subtle)}.so-pagination__page:focus-visible{outline:2px solid var(--so-ring);outline-offset:-1px}.so-pagination__button:focus-visible{outline:2px solid var(--so-ring);outline-offset:-1px}.so-pagination__page--active{background-color:var(--so-color-primary-base);color:var(--so-color-primary-fg);border-color:var(--so-color-primary-base)}.so-pagination__page--active:hover{background-color:var(--so-color-primary-base)}.so-pagination__ellipsis{display:inline-flex;align-items:center;justify-content:center;color:var(--so-text-muted);min-width:1.5em;-webkit-user-select:none;user-select:none}.so-pagination--sm .so-pagination__page{height:var(--so-control-height-sm);padding:0 var(--so-space-1);font-size:var(--so-font-size-sm)}.so-pagination--sm .so-pagination__ellipsis{font-size:var(--so-font-size-sm)}.so-pagination--md .so-pagination__page{height:var(--so-control-height-md);padding:0 var(--so-space-2);font-size:var(--so-font-size-md)}.so-popover-anchor{display:inline-flex;position:relative}.so-popover-trigger{display:inline-flex;align-items:center;background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer}.so-popover{position:absolute;z-index:1000;background-color:var(--so-bg);border:1px solid var(--so-border);border-radius:var(--so-radius);box-shadow:0 4px 16px #0000001f;padding:var(--so-space-2);min-width:120px;animation:so-popover-in .15s ease-out}@keyframes so-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.so-popover{animation:none}}.so-progress{width:100%;background-color:var(--so-border);border-radius:var(--so-radius);overflow:hidden}.so-progress--sm{height:4px}.so-progress--md{height:8px}.so-progress__bar{height:100%;border-radius:var(--so-radius);transition:width .3s ease}.so-progress--info .so-progress__bar{background-color:var(--so-color-info-base)}.so-progress--success .so-progress__bar{background-color:var(--so-color-success-base)}.so-progress--warning .so-progress__bar{background-color:var(--so-color-warning-base)}.so-progress--danger .so-progress__bar{background-color:var(--so-color-danger-base)}.so-radio-button{display:inline-flex;align-items:center;gap:var(--so-space-2);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:var(--so-line-height)}.so-radio-button--disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-radio-button__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.so-radio-button__indicator{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:2px solid var(--so-border);border-radius:50%;background-color:var(--so-bg);flex-shrink:0;transition:border-color .15s}.so-radio-button__input:checked+.so-radio-button__indicator{border-color:var(--so-color-primary-base)}.so-radio-button__input:focus-visible+.so-radio-button__indicator{outline:2px solid var(--so-ring);outline-offset:2px}.so-radio-button__dot{width:8px;height:8px;border-radius:50%;background-color:transparent;transition:background-color .15s}.so-radio-button__input:checked+.so-radio-button__indicator .so-radio-button__dot{background-color:var(--so-color-primary-base)}.so-radio-button__label{color:var(--so-text);font-size:var(--so-font-size-md)}.so-radio-group{border:none;padding:0;margin:0}.so-radio-group__label{font-size:var(--so-font-size-sm);font-weight:500;color:var(--so-text);line-height:var(--so-line-height);margin-bottom:var(--so-space-2)}.so-radio-group__items{display:flex;flex-direction:column;gap:var(--so-space-2)}.so-radio-group__error{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-color-danger-base)}.so-radio-group__hint{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-text-muted)}.so-select__wrapper{position:relative;width:100%}.so-select__input{width:100%;border:1px solid var(--so-border);border-radius:var(--so-radius);background-color:var(--so-bg);color:var(--so-text);font-family:inherit;line-height:var(--so-line-height);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.so-select__arrow{position:absolute;right:var(--so-space-3);top:50%;transform:translateY(-50%);width:12px;height:12px;pointer-events:none;color:var(--so-text-muted)}.so-select__input:focus{outline:2px solid var(--so-ring);outline-offset:-1px;border-color:transparent}.so-select__input:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-select__input[aria-invalid=true]{border-color:var(--so-color-danger-base)}.so-select__input[aria-invalid=true]:focus{outline-color:var(--so-color-danger-base);border-color:transparent}.so-select__input--sm{height:var(--so-control-height-sm);padding:0 var(--so-space-5) 0 var(--so-space-2);font-size:var(--so-font-size-sm)}.so-select__input--md{height:var(--so-control-height-md);padding:0 var(--so-space-5) 0 var(--so-space-3);font-size:var(--so-font-size-md)}.so-select__input--lg{height:var(--so-control-height-lg);padding:0 var(--so-space-6) 0 var(--so-space-4);font-size:var(--so-font-size-lg)}.so-skeleton{background-color:var(--so-border);border-radius:var(--so-radius);animation:so-skeleton-pulse 1.5s ease-in-out infinite}.so-skeleton--text{width:100%;height:1em;border-radius:var(--so-radius)}.so-skeleton--circle{width:40px;height:40px;border-radius:50%}.so-skeleton--rect{width:100%;height:100px}@keyframes so-skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}@media(prefers-reduced-motion:reduce){.so-skeleton{animation:none}}.so-spacer{flex:1}.so-spinner{display:inline-block;border-style:solid;border-radius:50%;border-right-color:transparent;animation:so-spinner-spin .6s linear infinite}.so-spinner--sm{width:16px;height:16px;border-width:2px}.so-spinner--md{width:24px;height:24px;border-width:2px}.so-spinner--lg{width:36px;height:36px;border-width:3px}.so-spinner--primary{border-color:var(--so-color-primary-base);border-right-color:transparent}.so-spinner--neutral{border-color:var(--so-color-neutral-base);border-right-color:transparent}@keyframes so-spinner-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.so-spinner{animation:none}}.so-stack{display:flex;flex-direction:column}.so-stack--gap-1{gap:var(--so-space-1)}.so-stack--gap-2{gap:var(--so-space-2)}.so-stack--gap-3{gap:var(--so-space-3)}.so-stack--gap-4{gap:var(--so-space-4)}.so-stack--gap-5{gap:var(--so-space-5)}.so-stack--gap-6{gap:var(--so-space-6)}.so-stack--align-start{align-items:flex-start}.so-stack--align-center{align-items:center}.so-stack--align-end{align-items:flex-end}.so-stack--align-stretch{align-items:stretch}.so-stack--justify-start{justify-content:flex-start}.so-stack--justify-center{justify-content:center}.so-stack--justify-end{justify-content:flex-end}.so-stack--justify-between{justify-content:space-between}.so-stack--justify-around{justify-content:space-around}.so-switch{display:inline-flex;align-items:center;gap:var(--so-space-2);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:var(--so-line-height)}.so-switch--disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-switch__track{position:relative;display:inline-flex;align-items:center;border:none;border-radius:9999px;background-color:var(--so-color-neutral-border);cursor:inherit;padding:2px;flex-shrink:0;transition:background-color .2s}.so-switch__track[aria-checked=true]{background-color:var(--so-color-primary-base)}.so-switch__track:focus-visible{outline:2px solid var(--so-ring);outline-offset:2px}.so-switch__track:disabled{cursor:not-allowed}.so-switch__thumb{display:block;border-radius:50%;background-color:var(--so-bg);transition:transform .2s;flex-shrink:0}.so-switch__label{color:var(--so-text)}.so-switch--sm .so-switch__track{width:28px;height:16px}.so-switch--sm .so-switch__thumb{width:12px;height:12px}.so-switch--sm .so-switch__track[aria-checked=true] .so-switch__thumb{transform:translate(12px)}.so-switch--sm .so-switch__label{font-size:var(--so-font-size-sm)}.so-switch--md .so-switch__track{width:40px;height:22px}.so-switch--md .so-switch__thumb{width:18px;height:18px}.so-switch--md .so-switch__track[aria-checked=true] .so-switch__thumb{transform:translate(18px)}.so-switch--md .so-switch__label{font-size:var(--so-font-size-md)}.so-switch-wrapper--error .so-switch__track{outline:2px solid var(--so-color-danger-base);outline-offset:2px}.so-switch__error{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-color-danger-base)}.so-switch__hint{margin:var(--so-space-1) 0 0;font-size:var(--so-font-size-sm);color:var(--so-text-muted)}.so-table-wrapper{overflow-x:auto;border:1px solid var(--so-border);border-radius:var(--so-radius)}.so-table{width:100%;border-collapse:collapse;font-size:var(--so-font-size-md);color:var(--so-text)}.so-table__row--header{background-color:var(--so-bg-subtle)}.so-table__header{font-weight:600;text-align:start;white-space:nowrap}.so-table__cell{padding:var(--so-space-3) var(--so-space-4);border-bottom:1px solid var(--so-border)}.so-table__cell--start{text-align:start}.so-table__cell--center{text-align:center}.so-table__cell--end{text-align:end}.so-table__cell--checkbox{width:40px;text-align:center}.so-table__row:last-child .so-table__cell{border-bottom:none}.so-table__row--selected{background-color:var(--so-color-primary-subtle)}.so-table__row:hover:not(.so-table__row--header){background-color:var(--so-bg-subtle)}.so-table__row--selected:hover{background-color:var(--so-color-primary-subtle)}.so-table__sort-button{display:inline-flex;align-items:center;gap:var(--so-space-1);padding:0;border:none;background:none;font:inherit;font-weight:600;color:inherit;cursor:pointer}.so-table__sort-icon{display:inline-flex;align-items:center;margin-left:var(--so-space-1)}.so-table__sort-icon:after{content:"↕";font-size:1em;opacity:.35}.so-table__sort-icon--asc:after{content:"▲";font-size:.7em;opacity:1}.so-table__sort-icon--desc:after{content:"▼";font-size:.7em;opacity:1}.so-tabs{display:flex;flex-direction:column}.so-tab-list{display:flex;border-bottom:1px solid var(--so-border);gap:0}.so-tab{display:inline-flex;align-items:center;justify-content:center;padding:var(--so-space-2) var(--so-space-4);border:none;border-bottom:2px solid transparent;background:none;font:inherit;font-size:var(--so-font-size-md);font-weight:500;color:var(--so-text-muted);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;margin-bottom:-1px}.so-tab:hover:not(:disabled){color:var(--so-text)}.so-tab:focus-visible{outline:2px solid var(--so-ring);outline-offset:-1px}.so-tab--active{color:var(--so-color-primary-base);border-bottom-color:var(--so-color-primary-base)}.so-tab:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-tab-panel{padding:var(--so-space-4) 0;color:var(--so-text)}.so-tag{display:inline-flex;align-items:center;gap:var(--so-space-1);border-radius:var(--so-radius);font-weight:500;line-height:1;white-space:nowrap}.so-tag--sm{padding:var(--so-space-1) var(--so-space-2);font-size:var(--so-font-size-sm)}.so-tag--md{padding:var(--so-space-1) var(--so-space-3);font-size:var(--so-font-size-md)}.so-tag--primary{background-color:var(--so-color-primary-subtle);color:var(--so-color-primary-subtle-fg)}.so-tag--neutral{background-color:var(--so-color-neutral-subtle);color:var(--so-color-neutral-subtle-fg)}.so-tag--danger{background-color:var(--so-color-danger-subtle);color:var(--so-color-danger-subtle-fg)}.so-tag--success{background-color:var(--so-color-success-subtle);color:var(--so-color-success-subtle-fg)}.so-tag--warning{background-color:var(--so-color-warning-subtle);color:var(--so-color-warning-subtle-fg)}.so-tag--info{background-color:var(--so-color-info-subtle);color:var(--so-color-info-subtle-fg)}.so-tag--solid.so-tag--primary{background-color:var(--so-color-primary-base);color:var(--so-color-primary-fg)}.so-tag--solid.so-tag--neutral{background-color:var(--so-color-neutral-base);color:var(--so-color-neutral-fg)}.so-tag--solid.so-tag--danger{background-color:var(--so-color-danger-base);color:var(--so-color-danger-fg)}.so-tag--solid.so-tag--success{background-color:var(--so-color-success-base);color:var(--so-color-success-fg)}.so-tag--solid.so-tag--warning{background-color:var(--so-color-warning-base);color:var(--so-color-warning-fg)}.so-tag--solid.so-tag--info{background-color:var(--so-color-info-base);color:var(--so-color-info-fg)}.so-tag__remove{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;padding:0;border:none;background:none;color:inherit;cursor:pointer;border-radius:2px;opacity:.7;transition:opacity .15s;font-size:inherit;line-height:1}.so-tag__remove:hover{opacity:1}.so-textarea__input{width:100%;border:1px solid var(--so-border);border-radius:var(--so-radius);background-color:var(--so-bg);color:var(--so-text);font-family:inherit;font-size:var(--so-font-size-md);line-height:var(--so-line-height);padding:var(--so-space-2) var(--so-space-3);resize:vertical;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.so-textarea__input::placeholder{color:var(--so-text-muted)}.so-textarea__input:focus{outline:2px solid var(--so-ring);outline-offset:-1px;border-color:transparent}.so-textarea__input:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-textarea__input[aria-invalid=true]{border-color:var(--so-color-danger-base)}.so-textarea__input[aria-invalid=true]:focus{outline-color:var(--so-color-danger-base);border-color:transparent}.so-textarea__input--sm{padding:var(--so-space-1) var(--so-space-2);font-size:var(--so-font-size-sm)}.so-textarea__input--md{padding:var(--so-space-2) var(--so-space-3);font-size:var(--so-font-size-md)}.so-textarea__input--lg{padding:var(--so-space-3) var(--so-space-4);font-size:var(--so-font-size-lg)}.so-text-field__input{width:100%;border:1px solid var(--so-border);border-radius:var(--so-radius);background-color:var(--so-bg);color:var(--so-text);font-family:inherit;line-height:var(--so-line-height);transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.so-text-field__input::placeholder{color:var(--so-text-muted)}.so-text-field__input:focus{outline:2px solid var(--so-ring);outline-offset:-1px;border-color:transparent}.so-text-field__input:disabled{opacity:var(--so-disabled-opacity);cursor:not-allowed}.so-text-field__input[aria-invalid=true]{border-color:var(--so-color-danger-base)}.so-text-field__input[aria-invalid=true]:focus{outline-color:var(--so-color-danger-base);border-color:transparent}.so-text-field__input--sm{height:var(--so-control-height-sm);padding:0 var(--so-space-2);font-size:var(--so-font-size-sm)}.so-text-field__input--md{height:var(--so-control-height-md);padding:0 var(--so-space-3);font-size:var(--so-font-size-md)}.so-text-field__input--lg{height:var(--so-control-height-lg);padding:0 var(--so-space-4);font-size:var(--so-font-size-lg)}.so-toast-container{position:fixed;z-index:1100;display:flex;flex-direction:column;gap:var(--so-space-2);padding:var(--so-space-4);pointer-events:none}.so-toast-container--top-right{top:0;right:0}.so-toast-container--top-center{top:0;left:50%;transform:translate(-50%)}.so-toast-container--bottom-right{bottom:0;right:0}.so-toast-container--bottom-center{bottom:0;left:50%;transform:translate(-50%)}.so-toast{display:flex;align-items:center;gap:var(--so-space-3);padding:var(--so-space-3) var(--so-space-4);border-radius:var(--so-radius);font-size:var(--so-font-size-md);box-shadow:0 4px 16px #00000026;min-width:280px;max-width:420px;pointer-events:auto;animation:so-toast-enter .2s ease-out}.so-toast__message{flex:1}.so-toast__dismiss{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:none;font-size:18px;line-height:1;cursor:pointer;border-radius:var(--so-radius);opacity:.7;color:inherit}.so-toast__dismiss:hover{opacity:1}.so-toast--info{background-color:var(--so-color-info-subtle);color:var(--so-color-info-subtle-fg);border-left:4px solid var(--so-color-info-base)}.so-toast--success{background-color:var(--so-color-success-subtle);color:var(--so-color-success-subtle-fg);border-left:4px solid var(--so-color-success-base)}.so-toast--warning{background-color:var(--so-color-warning-subtle);color:var(--so-color-warning-subtle-fg);border-left:4px solid var(--so-color-warning-base)}.so-toast--danger{background-color:var(--so-color-danger-subtle);color:var(--so-color-danger-subtle-fg);border-left:4px solid var(--so-color-danger-base)}.so-toast--dismissing{animation:so-toast-exit .15s ease-in forwards}@keyframes so-toast-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes so-toast-exit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@media(prefers-reduced-motion:reduce){.so-toast,.so-toast--dismissing{animation:none}}.so-tooltip-wrapper{position:relative;display:inline-flex}.so-tooltip{position:absolute;z-index:1000;padding:var(--so-space-1) var(--so-space-2);border-radius:var(--so-radius);background-color:var(--so-text);color:var(--so-bg);font-size:var(--so-font-size-sm);line-height:var(--so-line-height);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s}.so-tooltip-wrapper:hover .so-tooltip,.so-tooltip-wrapper:focus-within .so-tooltip{opacity:1}.so-tooltip--top{bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.so-tooltip--bottom{top:calc(100% + 6px);left:50%;transform:translate(-50%)}.so-tooltip--left{right:calc(100% + 6px);top:50%;transform:translateY(-50%)}.so-tooltip--right{left:calc(100% + 6px);top:50%;transform:translateY(-50%)}.so-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.site{min-height:100vh;display:flex;flex-direction:column}.site-header{display:flex;align-items:center;gap:var(--so-space-4);padding:var(--so-space-3) var(--so-space-5);border-bottom:1px solid var(--so-border);background:var(--so-bg-subtle)}.site-logo{font-size:20px;font-weight:700;color:var(--so-primary);text-decoration:none}.site-nav{display:flex;gap:var(--so-space-2)}.site-nav-link{font-size:var(--so-font-size-sm);font-weight:500;color:var(--so-text-muted);text-decoration:none;padding:var(--so-space-1) var(--so-space-2);border-radius:var(--so-radius);transition:background .15s,color .15s}.site-nav-link:hover{color:var(--so-text);background:var(--so-bg)}.site-nav-link.active{color:var(--so-primary);background:var(--so-primary-subtle)}.site-controls{display:flex;gap:var(--so-space-2)}.site-main{flex:1}.github-link{display:flex;align-items:center;color:var(--so-text-muted);transition:color .15s}.github-link:hover{color:var(--so-text)}.components-page{display:flex;min-height:calc(100vh - 56px)}.components-sidebar{width:220px;flex-shrink:0;position:sticky;top:0;height:calc(100vh - 56px);overflow-y:auto;border-right:1px solid var(--so-border);background:var(--so-bg-subtle);padding:var(--so-space-3)}.sidebar-search{margin-bottom:var(--so-space-3)}.sidebar-search-input{width:100%;padding:var(--so-space-2);font-size:var(--so-font-size-sm);border:1px solid var(--so-border);border-radius:var(--so-radius);background:var(--so-bg);color:var(--so-text);outline:none;box-sizing:border-box}.sidebar-search-input:focus{border-color:var(--so-primary);box-shadow:0 0 0 2px var(--so-primary-subtle)}.sidebar-search-input::placeholder{color:var(--so-text-muted)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--so-space-1)}.sidebar-category{margin-bottom:var(--so-space-2)}.sidebar-category-label{font-size:var(--so-font-size-xs);font-weight:600;color:var(--so-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--so-space-1) var(--so-space-2);margin-bottom:var(--so-space-1)}.sidebar-link{display:block;font-size:var(--so-font-size-sm);color:var(--so-text-muted);text-decoration:none;padding:2px var(--so-space-2) 2px var(--so-space-3);border-radius:var(--so-radius);transition:background .15s,color .15s}.sidebar-link:hover{color:var(--so-text);background:var(--so-bg)}.sidebar-link--active{color:var(--so-primary);background:var(--so-primary-subtle);font-weight:500}.components-content{flex:1;max-width:960px;padding:var(--so-space-5)}.components-badges{display:flex;flex-wrap:wrap;gap:var(--so-space-1);margin-bottom:var(--so-space-4)}.components-badge-link{text-decoration:none}.components-badge-link:hover .so-badge{background:var(--so-primary-subtle);color:var(--so-primary)}.components-category{margin-bottom:var(--so-space-6)}.components-category h2{font-size:20px;font-weight:600;color:var(--so-text);margin-bottom:var(--so-space-3);padding-bottom:var(--so-space-2);border-bottom:1px solid var(--so-border)}.component-card-anchor{margin-bottom:var(--so-space-4);scroll-margin-top:16px}.component-card-name{font-size:var(--so-font-size-lg);font-weight:600}.component-card-desc{font-size:var(--so-font-size-sm);color:var(--so-text-muted);margin-top:var(--so-space-1);margin-bottom:0;line-height:1.4}.component-demo{padding:var(--so-space-3) 0}.component-code{padding:var(--so-space-2) 0}.code-block{background:var(--so-bg-subtle);border:1px solid var(--so-border);border-radius:var(--so-radius);padding:var(--so-space-3);font-size:var(--so-font-size-sm);color:var(--so-text);overflow-x:auto;line-height:1.5;margin:0}.component-api{padding:var(--so-space-2) 0}.api-sub-section{margin-bottom:var(--so-space-3)}.api-sub-name{font-size:var(--so-font-size-md);font-weight:600;color:var(--so-text);margin-bottom:var(--so-space-2)}.catalog-row{display:flex;gap:var(--so-space-3);flex-wrap:wrap;align-items:center;margin-bottom:var(--so-space-3)}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--so-space-3);margin-bottom:var(--so-space-3)}.top-page{max-width:960px;margin:0 auto;padding:var(--so-space-5)}.top-hero{text-align:center;padding:var(--so-space-6) 0}.top-hero h1{font-size:48px;font-weight:700;color:var(--so-primary);margin-bottom:var(--so-space-3)}.top-hero-sub{font-size:var(--so-font-size-lg);color:var(--so-text-muted);margin-bottom:var(--so-space-4)}.top-install{display:inline-block;background:var(--so-bg-subtle);border:1px solid var(--so-border);border-radius:var(--so-radius);padding:var(--so-space-2) var(--so-space-4);font-size:var(--so-font-size-md);color:var(--so-text)}.top-features{margin-bottom:var(--so-space-6)}.top-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--so-space-3)}.top-feature-card,.top-category-card{padding:var(--so-space-4);border:1px solid var(--so-border);border-radius:var(--so-radius);background:var(--so-bg)}.top-feature-card h3,.top-category-card h3{font-size:var(--so-font-size-md);font-weight:600;color:var(--so-text);margin-bottom:var(--so-space-2)}.top-feature-card p,.top-category-card p{font-size:var(--so-font-size-sm);color:var(--so-text-muted);line-height:1.5}.top-categories{margin-bottom:var(--so-space-6)}.top-categories h2{font-size:20px;font-weight:600;color:var(--so-text);margin-bottom:var(--so-space-3)}.top-links{display:flex;gap:var(--so-space-3);margin-top:var(--so-space-4);justify-content:center}.top-link{display:inline-block;padding:var(--so-space-2) var(--so-space-4);background:var(--so-primary);color:#fff;border-radius:var(--so-radius);text-decoration:none;font-weight:500;font-size:var(--so-font-size-sm);transition:opacity .15s}.top-link:hover{opacity:.85}.gs-page{max-width:720px;margin:0 auto;padding:var(--so-space-5)}.gs-page h1{font-size:28px;font-weight:700;color:var(--so-text)}.gs-page p{font-size:var(--so-font-size-md);color:var(--so-text);line-height:1.6;margin-bottom:var(--so-space-2)}.gs-page p code,.gs-page li code{font-size:var(--so-font-size-sm);background:var(--so-bg-subtle);padding:1px 4px;border-radius:3px}.gs-list{margin:0 0 var(--so-space-2);padding-left:var(--so-space-4);font-size:var(--so-font-size-md);color:var(--so-text);line-height:1.8}.gs-code{background:var(--so-bg-subtle);border:1px solid var(--so-border);border-radius:var(--so-radius);padding:var(--so-space-3);font-size:var(--so-font-size-sm);color:var(--so-text);overflow-x:auto;margin-bottom:var(--so-space-2);line-height:1.5}.api-description{font-size:var(--so-font-size-sm);color:var(--so-text-muted);margin-bottom:var(--so-space-3)}.api-table{width:100%;border-collapse:collapse;font-size:var(--so-font-size-sm)}.api-table th{text-align:left;font-weight:500;color:var(--so-text-muted);padding:var(--so-space-2);border-bottom:1px solid var(--so-border)}.api-table td{padding:var(--so-space-2);border-bottom:1px solid var(--so-border);color:var(--so-text)}.api-table code{font-size:var(--so-font-size-sm);background:var(--so-bg-subtle);padding:1px 4px;border-radius:3px}
