:root{--color-primary-50: #f4f0ff;--color-primary-100: #ebe5ff;--color-primary-200: #d9ccff;--color-primary-300: #bea6ff;--color-primary-400: #a375ff;--color-primary-500: #8a3dff;--color-primary-600: #7a1bf2;--color-primary-700: #690cd6;--color-primary-800: #580aa8;--color-primary-900: #490987;--color-primary-950: #2e005b;--color-secondary-50: #ecfdf5;--color-secondary-100: #d1fae5;--color-secondary-200: #a7f3d0;--color-secondary-300: #6ee7b7;--color-secondary-400: #34d399;--color-secondary-500: #10b981;--color-secondary-600: #059669;--color-secondary-700: #047857;--color-secondary-800: #065f46;--color-secondary-900: #064e3b;--color-secondary-950: #022c22;--color-neutral-50: #fafafa;--color-neutral-100: #f4f4f5;--color-neutral-200: #e4e4e7;--color-neutral-300: #d4d4d8;--color-neutral-400: #a1a1aa;--color-neutral-500: #71717a;--color-neutral-600: #52525b;--color-neutral-700: #3f3f46;--color-neutral-800: #27272a;--color-neutral-900: #18181b;--color-neutral-950: #09090b;--color-success: var(--color-secondary-500);--color-error: #ef4444;--color-warning: #f59e0b;--color-info: #3b82f6;--color-bg-default: #ffffff;--color-bg-subtle: var(--color-neutral-100);--color-bg-surface: #ffffff;--color-text-primary: var(--color-neutral-900);--color-text-secondary: var(--color-neutral-600);--color-text-tertiary: var(--color-neutral-400);--color-border: var(--color-neutral-200);--font-family-sans: "Inter", system-ui, -apple-system, sans-serif;--font-family-mono: "JetBrains Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg-default: #000000;--color-bg-subtle: var(--color-neutral-800);--color-bg-surface: #09090b;--color-text-primary: #ffffff;--color-text-secondary: #a1a1aa;--color-text-tertiary: #52525b;--color-border: #3f3f46}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-sans);background-color:var(--color-bg-default);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"rlig" 1,"calt" 1;transition:background-color var(--transition-normal),color var(--transition-normal);container-type:inline-size}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}.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}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stack{display:flex;flex-direction:column}.hstack{display:flex;flex-direction:row}.stack-wrap{flex-wrap:wrap}.stack-gap-none{gap:0}.stack-gap-xs{gap:var(--spacing-1)}.stack-gap-sm{gap:var(--spacing-2)}.stack-gap-md{gap:var(--spacing-4)}.stack-gap-lg{gap:var(--spacing-6)}.stack-gap-xl{gap:var(--spacing-8)}.stack-gap-2xl{gap:var(--spacing-10)}.stack-align-start{align-items:flex-start}.stack-align-center{align-items:center}.stack-align-end{align-items:flex-end}.stack-align-stretch{align-items:stretch}.stack-justify-start{justify-content:flex-start}.stack-justify-center{justify-content:center}.stack-justify-end{justify-content:flex-end}.stack-justify-between{justify-content:space-between}.stack-justify-around{justify-content:space-around}.hstack-align-start{align-items:flex-start}.hstack-align-center{align-items:center}.hstack-align-end{align-items:flex-end}.hstack-align-stretch{align-items:stretch}.hstack-justify-start{justify-content:flex-start}.hstack-justify-center{justify-content:center}.hstack-justify-end{justify-content:flex-end}.hstack-justify-between{justify-content:space-between}.hstack-justify-around{justify-content:space-around}.top-banner{height:64px;background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--spacing-6);position:sticky;top:0;z-index:50;justify-content:space-between}.top-banner-brand{flex-wrap:nowrap}.top-banner-logo{width:32px;height:32px;background-color:var(--color-primary-600);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.top-banner-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;white-space:nowrap}.top-banner-version{background:transparent;border:1px solid var(--color-border);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer}.top-banner-version:hover{background-color:var(--color-bg-subtle)}.search-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.search-container{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-left:var(--spacing-10);padding-right:var(--spacing-10);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.search-input:hover:not(:disabled){border-color:var(--color-neutral-400)}.search-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.search-input:disabled{background-color:var(--color-neutral-100);color:var(--color-text-tertiary);cursor:not-allowed}.search-icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none;display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem}.search-action{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer}.search-action:hover{color:var(--color-text-primary)}.search-loading{animation:spin 1s linear infinite;color:var(--color-primary-500);pointer-events:none}.search-clear-icon{width:1.25rem;height:1.25rem}.container{width:100%;margin-left:auto;margin-right:auto;padding-left:var(--spacing-4);padding-right:var(--spacing-4)}@media(min-width:768px){.container{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}}.container-sm{max-width:400px}.container-md{max-width:600px}.container-lg{max-width:800px}.container-xl{max-width:1200px}.container-full{max-width:100%}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;background-color:var(--color-bg-default);position:relative}.layout-body{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;height:100%;overflow-y:auto;border-right:1px solid var(--color-border);padding:var(--spacing-6);background-color:var(--color-bg-surface);display:flex;flex-direction:column;gap:var(--spacing-6);flex-shrink:0;transition:transform var(--transition-normal);z-index:50}.sidebar-header{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--spacing-4)}.sidebar-search{position:relative;margin-bottom:var(--spacing-2)}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.nav-section-title{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin:var(--spacing-4) 0 var(--spacing-2) var(--spacing-3)}.nav-divider{height:1px;background-color:var(--color-border);margin:var(--spacing-2) 0}.nav-link{padding:var(--spacing-2) var(--spacing-3);color:var(--color-text-secondary);background-color:transparent;text-decoration:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);transition:all var(--transition-fast);display:block}.nav-link:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}.nav-link.active{color:var(--color-primary-600);background-color:var(--color-primary-50);font-weight:var(--font-weight-semibold)}.main-content{flex:1;padding:var(--spacing-10) 0;width:100%;height:100%;overflow-y:auto}.mobile-menu-btn{display:none;position:fixed;top:var(--spacing-4);right:var(--spacing-4);z-index:60;padding:var(--spacing-2);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:40;opacity:0;transition:opacity var(--transition-normal)}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;height:100vh;transform:translate(-100%);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block;opacity:1}.main-content{padding:var(--spacing-8) 0}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-8);padding-bottom:var(--spacing-6)}.page-header-content{display:flex;flex-direction:column;gap:var(--spacing-2);flex:1}.page-header-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:1.2}.page-header-description{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:1.5;max-width:65ch}.page-header-actions{display:flex;align-items:center;gap:var(--spacing-3)}@media(max-width:640px){.page-header{flex-direction:column;align-items:stretch}.page-header-actions{align-self:flex-start}}.card{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-fast),transform var(--transition-fast);display:flex;flex-direction:column}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.card-body{padding:var(--spacing-6);flex-grow:1;color:var(--color-text-secondary)}.card-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border);background-color:var(--color-bg-subtle);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3)}.card-image{width:100%;height:auto;object-fit:cover}.card-image-container{position:relative;width:100%;padding-top:56.25%;overflow:hidden}.card-image-container img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.alert{display:flex;align-items:flex-start;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);border:1px solid transparent;margin-bottom:var(--spacing-4);font-size:var(--font-size-sm);line-height:1.5}.alert-content{flex-grow:1;margin-left:var(--spacing-3)}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.alert-icon{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:.125rem}.alert-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:0;margin-left:var(--spacing-3);color:currentColor;opacity:.6;transition:opacity var(--transition-fast)}.alert-close:hover{opacity:1}.alert-info{background-color:#eff6ff;border-color:#dbeafe;color:#1e40af}.alert-info .alert-icon{color:#2563eb}.alert-success{background-color:#f0fdf4;border-color:#dcfce7;color:#166534}.alert-success .alert-icon{color:#16a34a}.alert-warning{background-color:#fffbeb;border-color:#fef3c7;color:#92400e}.alert-warning .alert-icon{color:#d97706}.alert-error{background-color:#fef2f2;border-color:#fee2e2;color:#991b1b}.alert-error .alert-icon{color:#dc2626}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .5rem;font-size:.75rem;font-weight:var(--font-weight-medium);line-height:1.25;border-radius:var(--radius-full);white-space:nowrap}.badge-default{background-color:var(--color-neutral-100);color:var(--color-text-secondary)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-success{background-color:var(--color-secondary-100);color:var(--color-secondary-700)}.badge-warning{background-color:#fef3c7;color:#b45309}.badge-error{background-color:#fee2e2;color:#b91c1c}.badge-info{background-color:#dbeafe;color:#1d4ed8}.badge-sm{font-size:.7rem;padding:0 .375rem}.badge-md{font-size:.75rem;padding:.125rem .5rem}.badge-lg{font-size:.875rem;padding:.25rem .75rem}.badge-pill{border-radius:var(--radius-full)}.badge-tag{border-radius:var(--radius-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);white-space:nowrap;border-radius:var(--radius-md);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);line-height:1.25rem;padding:var(--spacing-2) var(--spacing-4);transition:all var(--transition-fast);cursor:pointer;border:1px solid transparent;outline:none;position:relative;overflow:hidden}.btn:focus-visible{box-shadow:0 0 0 2px var(--color-bg-default),0 0 0 4px var(--color-primary-500)}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary-600);color:#fff}.btn-primary:hover{background-color:var(--color-primary-700)}.btn-primary:active{background-color:var(--color-primary-800)}.btn-secondary{background-color:var(--color-bg-default);color:var(--color-text-primary);border-color:var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-subtle);border-color:var(--color-neutral-300)}.btn-secondary:active{background-color:var(--color-neutral-100)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background-color:var(--color-neutral-100);color:var(--color-text-primary)}.btn-ghost:active{background-color:var(--color-neutral-200)}.btn-destructive{background-color:var(--color-error);color:#fff}.btn-destructive:hover{background-color:#dc2626}.btn-destructive:active{background-color:#b91c1c}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base)}.btn-icon-only{padding:var(--spacing-2);aspect-ratio:1}.btn-icon-only.btn-sm{padding:var(--spacing-1)}.btn-icon-only.btn-lg{padding:var(--spacing-3)}.btn-loading{color:transparent!important;pointer-events:none;position:relative}.btn-loading>*{visibility:hidden}.btn-loading:after{content:"";position:absolute;width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .75s linear infinite;color:var(--color-text-primary);left:50%;top:50%;transform:translate(-50%,-50%)}.btn-primary.btn-loading:after,.btn-destructive.btn-loading:after{color:#fff}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.btn[aria-pressed=true]{background-color:var(--color-primary-100);color:var(--color-primary-700);border-color:var(--color-primary-200)}.btn-group{display:inline-flex;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.btn-group .btn{border-radius:0;border-left-width:0}.btn-group .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md);border-left-width:1px}.btn-group .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.btn-group .btn:focus-visible{z-index:1}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,var(--grid-min-child-width, 300px)),1fr))}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-gap-none{gap:0}.grid-gap-xs{gap:var(--spacing-1)}.grid-gap-sm{gap:var(--spacing-2)}.grid-gap-md{gap:var(--spacing-4)}.grid-gap-lg{gap:var(--spacing-6)}.grid-gap-xl{gap:var(--spacing-8)}@media(max-width:768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.icon svg{width:100%;height:100%}.icon-xs{width:12px;height:12px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}.icon-xl{width:32px;height:32px}.icon-primary{color:var(--color-primary-600)}.icon-secondary{color:var(--color-text-secondary)}.icon-muted{color:var(--color-text-tertiary)}.icon-success{color:var(--color-success-600)}.icon-warning{color:var(--color-warning-600)}.icon-error{color:var(--color-error-600)}.icon-info{color:var(--color-info-600)}.icon-inherit{color:inherit}.section-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.ai-section-header{margin-bottom:var(--spacing-4)}.ai-section-header .section-title{margin-bottom:0}.getting-started-text{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6}.concept-card{height:100%}.concept-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.concept-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.6}.concept-desc code{background-color:var(--color-bg-subtle);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-family:var(--font-family-mono);font-size:var(--font-size-xs);color:var(--color-primary-600)}.ai-example{display:flex;flex-direction:column;gap:var(--spacing-2)}.ai-badge{align-self:flex-start}.ai-message{font-size:var(--font-size-base);color:var(--color-text-primary);margin:0;padding:var(--spacing-3);background-color:var(--color-bg-subtle);border-radius:var(--radius-md)}.practice-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) 0;border-bottom:1px solid var(--color-border)}.practice-item:last-child{border-bottom:none}.practice-item span{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.component-category{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.next-steps-card{background:linear-gradient(135deg,var(--color-primary-50),var(--color-secondary-50));text-align:center}.next-steps-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.next-steps-desc{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-sm{font-size:var(--font-size-sm)}.font-semibold{font-weight:var(--font-weight-semibold)}code[class*=language-],pre[class*=language-]{color:#f8f8f2;background:none;text-shadow:0 1px rgba(0,0,0,.3);font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto;border-radius:.3em}:not(pre)>code[class*=language-],pre[class*=language-]{background:#272822}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#8292a2}.token.punctuation{color:#f8f8f2}.token.namespace{opacity:.7}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:#f92672}.token.boolean,.token.number{color:#ae81ff}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#a6e22e}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string,.token.variable{color:#f8f8f2}.token.atrule,.token.attr-value,.token.function,.token.class-name{color:#e6db74}.token.keyword{color:#66d9ef}.token.regex,.token.important{color:#fd971f}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}pre[class*=language-].line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}pre[class*=language-].line-numbers>code{position:relative;white-space:inherit}.line-numbers .line-numbers-rows{position:absolute;pointer-events:none;top:0;font-size:100%;left:-3.8em;width:3em;letter-spacing:-1px;border-right:1px solid #999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.line-numbers-rows>span{display:block;counter-increment:linenumber}.line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}.showcase-viewport-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:var(--color-bg-surface);z-index:9999;display:flex;flex-direction:column}.showcase-viewport-container{background-color:var(--color-bg-surface);flex:1;min-height:0;max-height:100%;border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:visible;transition:width .3s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid var(--color-neutral-300);container-type:inline-size}.showcase-viewport-container.resizing{transition:none;pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-inner{flex:1;display:flex;flex-direction:column;overflow:hidden;border-radius:inherit;width:100%;height:100%}.viewport-content{flex:1;overflow:auto;width:100%;height:100%;display:flex;justify-content:center;align-items:center;padding:var(--spacing-8)}.viewport-content.no-padding{padding:0;display:block}.resize-handle{position:absolute;top:50%;transform:translateY(-50%);width:6px;height:48px;background-color:var(--color-neutral-400);border-radius:var(--radius-full);cursor:col-resize;transition:background-color var(--transition-fast);z-index:10;right:-24px}.resize-handle:hover,.showcase-viewport-container.resizing .resize-handle{background-color:var(--color-primary-500)}.showcase-viewport-header{height:60px;background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;padding:0 var(--spacing-4);position:relative;box-shadow:var(--shadow-sm)}.showcase-viewport-controls{display:flex;background-color:transparent;padding:4px;border-radius:var(--radius-md);gap:4px}.viewport-btn{padding:var(--spacing-2);border:none;background:transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.viewport-btn:hover{background-color:var(--color-bg-surface);color:var(--color-text-primary)}.viewport-btn.active{background-color:var(--color-primary-600);color:#fff;box-shadow:var(--shadow-sm)}.showcase-viewport-title{position:absolute;left:var(--spacing-6);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.close-viewport-btn{position:absolute;right:var(--spacing-6);background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-2);border-radius:var(--radius-full);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.close-viewport-btn:hover{background-color:var(--color-error-light);color:var(--color-error)}.showcase-viewport-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-12) var(--spacing-8) var(--spacing-8);overflow:hidden;background-color:var(--color-bg-subtle);background-image:radial-gradient(var(--color-border) 1px,transparent 1px);background-size:20px 20px;position:relative}.showcase-viewport-body.no-padding{padding:var(--spacing-6) var(--spacing-12) var(--spacing-6) var(--spacing-6);background-image:none;background-color:var(--color-bg-surface)}.viewport-width-label{font-family:var(--font-family-mono);font-size:var(--font-size-xs);color:var(--color-text-secondary);background-color:var(--color-bg-surface);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);border:1px solid var(--color-border);position:absolute;bottom:var(--spacing-4);z-index:20;pointer-events:none}.component-showcase{border:1px solid var(--color-border);border-radius:var(--radius-xl);background-color:var(--color-bg-surface);overflow:hidden;margin-bottom:var(--spacing-8);display:flex;flex-direction:column}.showcase-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-border)}.showcase-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.showcase-description{color:var(--color-text-secondary);font-size:var(--font-size-base)}.showcase-preview{padding:var(--spacing-10);background-color:var(--color-bg-subtle);background-image:radial-gradient(var(--color-border) 1px,transparent 1px);background-size:20px 20px;min-height:240px;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden}.showcase-preview.no-padding{padding:0;display:block;background-image:none;background-color:var(--color-bg-surface)}.showcase-preview.resizing{-webkit-user-select:none;user-select:none;cursor:ns-resize}.preview-resize-handle{position:absolute;bottom:0;left:0;width:100%;height:12px;cursor:ns-resize;display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity .2s}.preview-resize-handle:after{content:"";width:40px;height:4px;background-color:var(--color-border);border-radius:var(--radius-full)}.showcase-preview:hover .preview-resize-handle,.preview-resize-handle:hover,.showcase-preview.resizing .preview-resize-handle{opacity:1}.preview-resize-handle:hover:after,.showcase-preview.resizing .preview-resize-handle:after{background-color:var(--color-primary-500)}.showcase-toolbar{display:flex;border-top:1px solid var(--color-border);background-color:var(--color-bg-subtle)}.toolbar-btn{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:none;border:none;border-right:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s}.toolbar-btn:hover{background-color:var(--color-bg-surface);color:var(--color-text-primary)}.toolbar-btn.active{background-color:var(--color-bg-default);color:var(--color-primary-600);box-shadow:inset 0 -2px 0 var(--color-primary-600)}.showcase-collapsible{border-top:1px solid var(--color-border);background-color:var(--color-bg-default);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.showcase-code-wrapper{position:relative}.showcase-code{margin:0!important;padding:var(--spacing-6)!important;font-size:var(--font-size-sm)!important;border-radius:0!important;max-height:400px;overflow:auto}.copy-btn{position:absolute;top:var(--spacing-4);right:var(--spacing-4);display:flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-xs);cursor:pointer;transition:all .2s;z-index:10}.copy-btn:hover{background-color:#fff3}.copy-btn.copied{background-color:var(--color-success);border-color:var(--color-success)}.a11y-report{padding:var(--spacing-6)}.a11y-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-4)}.a11y-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-4)}.a11y-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface)}.a11y-status{width:8px;height:8px;border-radius:50%}.a11y-status.pass{background-color:var(--color-success);box-shadow:0 0 0 2px var(--color-success-light)}.a11y-status.fail{background-color:var(--color-error);box-shadow:0 0 0 2px var(--color-error-light)}.a11y-label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.input-container{position:relative;display:flex;align-items:center}.input{width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.input:hover:not(:disabled){border-color:var(--color-neutral-400)}.input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.input:disabled{background-color:var(--color-neutral-100);color:var(--color-text-tertiary);cursor:not-allowed}.input-invalid{border-color:var(--color-error)}.input-invalid:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #fee2e2}.input-valid{border-color:var(--color-success)}.input-valid:focus{border-color:var(--color-success);box-shadow:0 0 0 3px var(--color-secondary-100)}.input-has-left-icon{padding-left:var(--spacing-10)}.input-has-right-icon{padding-right:var(--spacing-10)}.input-icon{position:absolute;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none;display:flex;align-items:center;justify-content:center;width:var(--spacing-10);height:100%}.input-icon-left{left:0}.input-icon-right{right:0}.input-loading .input-icon-right{animation:spin 1s linear infinite;color:var(--color-primary-500)}.chat-input-container{position:relative;width:100%;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-3);padding-right:var(--spacing-12);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);display:flex;align-items:flex-end}.chat-input-container:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.chat-input-textarea{width:100%;border:none;background:transparent;padding:0;margin:0;font-family:inherit;font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);resize:none;outline:none;max-height:200px}.chat-input-textarea::placeholder{color:var(--color-text-tertiary)}.chat-input-textarea:disabled{cursor:not-allowed;color:var(--color-text-tertiary)}.chat-input-send-btn{position:absolute;right:var(--spacing-2);bottom:var(--spacing-2);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-full);background-color:var(--color-primary-600);color:#fff;cursor:pointer;transition:all var(--transition-fast)}.chat-input-send-btn:hover:not(:disabled){background-color:var(--color-primary-700)}.chat-input-send-btn:disabled{background-color:var(--color-neutral-200);color:var(--color-neutral-400);cursor:not-allowed}.chat-input-icon{width:16px;height:16px}.textarea-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;min-height:80px;resize:vertical;font-family:inherit}.textarea:hover:not(:disabled){border-color:var(--color-neutral-400)}.textarea:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.textarea:disabled{background-color:var(--color-neutral-100);color:var(--color-text-tertiary);cursor:not-allowed;resize:none}.textarea-invalid{border-color:var(--color-error)}.textarea-invalid:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #fee2e2}.textarea-valid{border-color:var(--color-success)}.textarea-valid:focus{border-color:var(--color-success);box-shadow:0 0 0 3px var(--color-secondary-100)}.select-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.select-container{position:relative;display:flex;align-items:center}.select{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-right:var(--spacing-8);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;appearance:none;cursor:pointer}.select:hover:not(:disabled){border-color:var(--color-neutral-400)}.select:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.select:disabled{background-color:var(--color-neutral-100);color:var(--color-text-tertiary);cursor:not-allowed}.select-invalid{border-color:var(--color-error)}.select-invalid:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #fee2e2}.select-chevron{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center}.select:disabled+.select-chevron{color:var(--color-text-tertiary);opacity:.5}.checkbox-wrapper{display:flex;align-items:flex-start;gap:var(--spacing-2);cursor:pointer;position:relative}.checkbox-input{position:absolute;opacity:0;width:0;height:0}.checkbox-control{width:1.25rem;height:1.25rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-surface);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:#fff;flex-shrink:0;margin-top:2px}.checkbox-icon{width:12px;height:12px;stroke-width:4;opacity:0;transition:opacity var(--transition-fast)}.checkbox-wrapper:hover .checkbox-control{border-color:var(--color-neutral-400)}.checkbox-input:focus-visible+.checkbox-control{box-shadow:0 0 0 2px var(--color-bg-default),0 0 0 4px var(--color-primary-500)}.checkbox-input:checked+.checkbox-control{background-color:var(--color-primary-600);border-color:var(--color-primary-600)}.checkbox-input:checked+.checkbox-control .checkbox-icon{opacity:1}.checkbox-input:checked:hover+.checkbox-control{background-color:var(--color-primary-700);border-color:var(--color-primary-700)}.checkbox-input:disabled+.checkbox-control{background-color:var(--color-neutral-100);border-color:var(--color-neutral-200);color:var(--color-neutral-400);cursor:not-allowed}.checkbox-wrapper.disabled{cursor:not-allowed;color:var(--color-text-tertiary)}.checkbox-content{display:flex;flex-direction:column;gap:0}.checkbox-label{font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.checkbox-helper-text{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.4}.checkbox-wrapper.disabled .checkbox-label,.checkbox-wrapper.disabled .checkbox-helper-text{color:var(--color-text-tertiary)}.checkbox-indeterminate .checkbox-control{background-color:var(--color-primary-600);border-color:var(--color-primary-600)}.checkbox-indeterminate .checkbox-control .checkbox-icon{opacity:1}.checkbox-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.checkbox-group-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.checkbox-group-items{display:flex;flex-direction:column;gap:var(--spacing-2)}.checkbox-group-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-1)}.checkbox-group-helper{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.radio-wrapper{display:flex;align-items:flex-start;gap:var(--spacing-2);cursor:pointer;position:relative}.radio-input{position:absolute;opacity:0;width:0;height:0}.radio-control{width:1.25rem;height:1.25rem;border:1px solid var(--color-border);border-radius:50%;background-color:var(--color-bg-surface);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.radio-control:after{content:"";width:.625rem;height:.625rem;border-radius:50%;background-color:var(--color-primary-600);transform:scale(0);transition:transform var(--transition-fast)}.radio-wrapper:hover .radio-control{border-color:var(--color-neutral-400)}.radio-input:focus-visible+.radio-control{box-shadow:0 0 0 2px var(--color-bg-default),0 0 0 4px var(--color-primary-500)}.radio-input:checked+.radio-control{border-color:var(--color-primary-600)}.radio-input:checked+.radio-control:after{transform:scale(1)}.radio-input:disabled+.radio-control{background-color:var(--color-neutral-100);border-color:var(--color-neutral-200);cursor:not-allowed}.radio-input:disabled+.radio-control:after{background-color:var(--color-neutral-400)}.radio-wrapper.disabled{cursor:not-allowed;color:var(--color-text-tertiary)}.radio-label{font-size:var(--font-size-sm);line-height:1.25rem;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.radio-wrapper.disabled .radio-label{color:var(--color-text-tertiary)}.switch-wrapper{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;position:relative}.switch-input{position:absolute;opacity:0;width:0;height:0}.switch-control{width:2.25rem;height:1.25rem;border-radius:var(--radius-full);background-color:var(--color-neutral-200);position:relative;transition:background-color var(--transition-fast);flex-shrink:0}.switch-control:after{content:"";position:absolute;top:2px;left:2px;width:1rem;height:1rem;border-radius:50%;background-color:#fff;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.switch-wrapper:hover .switch-control{background-color:var(--color-neutral-300)}.switch-input:focus-visible+.switch-control{box-shadow:0 0 0 2px var(--color-bg-default),0 0 0 4px var(--color-primary-500)}.switch-input:checked+.switch-control{background-color:var(--color-primary-600)}.switch-input:checked:hover+.switch-control{background-color:var(--color-primary-700)}.switch-input:checked+.switch-control:after{transform:translate(1rem)}.switch-input:disabled+.switch-control{background-color:var(--color-neutral-100);cursor:not-allowed;opacity:.5}.switch-wrapper.disabled{cursor:not-allowed;color:var(--color-text-tertiary)}.switch-label{font-size:var(--font-size-sm);line-height:1.25rem;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.switch-wrapper.disabled .switch-label{color:var(--color-text-tertiary)}.slider-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2);width:100%}.slider-container{position:relative;height:1.25rem;display:flex;align-items:center}.slider-input{-webkit-appearance:none;appearance:none;width:100%;height:.375rem;background:var(--color-neutral-200);border-radius:var(--radius-full);outline:none;transition:background var(--transition-fast);cursor:pointer}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:1.25rem;height:1.25rem;border-radius:50%;background:#fff;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.slider-input::-moz-range-thumb{width:1.25rem;height:1.25rem;border-radius:50%;background:#fff;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.slider-input:hover::-webkit-slider-thumb{transform:scale(1.1);box-shadow:var(--shadow-md)}.slider-input:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 2px var(--color-bg-default),0 0 0 4px var(--color-primary-500)}.slider-input:disabled{background:var(--color-neutral-100);cursor:not-allowed}.slider-input:disabled::-webkit-slider-thumb{background:var(--color-neutral-100);border-color:var(--color-neutral-200);cursor:not-allowed;box-shadow:none}.slider-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:flex;justify-content:space-between}.slider-value{color:var(--color-text-secondary);font-feature-settings:"tnum"}.file-upload-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.file-upload-container{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-subtle);transition:all var(--transition-fast);cursor:pointer;text-align:center}.file-upload-container:hover:not(.disabled){border-color:var(--color-primary-400);background-color:var(--color-primary-50)}.file-upload-container.drag-over{border-color:var(--color-primary-500);background-color:var(--color-primary-100)}.file-upload-container.disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-neutral-100)}.file-upload-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-upload-input:disabled{cursor:not-allowed}.file-upload-icon{width:3rem;height:3rem;color:var(--color-text-tertiary);margin-bottom:var(--spacing-2);transition:color var(--transition-fast)}.file-upload-container:hover .file-upload-icon{color:var(--color-primary-500)}.file-upload-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.file-upload-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.file-list{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-2)}.file-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.file-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.file-size{color:var(--color-text-tertiary);font-size:var(--font-size-xs);margin-left:var(--spacing-2)}.file-remove{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.file-remove:hover{background-color:var(--color-neutral-100);color:var(--color-error)}.datepicker-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1);width:100%}.datepicker-container{position:relative;display:flex;align-items:center}.datepicker-input{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-right:var(--spacing-10);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;font-family:inherit}.datepicker-input:hover:not(:disabled){border-color:var(--color-neutral-400)}.datepicker-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.datepicker-input:disabled{background-color:var(--color-neutral-100);color:var(--color-text-tertiary);cursor:not-allowed}.datepicker-input::-webkit-calendar-picker-indicator{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);cursor:pointer;opacity:0;width:1.5rem;height:1.5rem;z-index:10}.datepicker-icon{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center}.datepicker-invalid{border-color:var(--color-error)}.datepicker-invalid:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #fee2e2}.datepicker-valid{border-color:var(--color-success)}.datepicker-valid:focus{border-color:var(--color-success);box-shadow:0 0 0 3px var(--color-secondary-100)}.navbar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-6);background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);height:4rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-2);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-text-primary);text-decoration:none}.navbar-nav{display:flex;align-items:center;gap:var(--spacing-4);list-style:none;margin:0;padding:0}.navbar-item{display:flex;align-items:center}.navbar-link{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;padding:var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.navbar-link:hover{color:var(--color-text-primary);background-color:var(--color-bg-subtle)}.navbar-link.active{color:var(--color-primary-600);background-color:var(--color-primary-50)}.navbar-actions{display:flex;align-items:center;gap:var(--spacing-3)}.navbar-toggle{display:none;background:none;border:none;color:var(--color-text-primary);cursor:pointer;padding:var(--spacing-2)}@media(max-width:768px){.navbar-nav{display:none}.navbar-toggle{display:block}.navbar.expanded .navbar-nav{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-4);box-shadow:var(--shadow-md)}.navbar.expanded .navbar-item{width:100%}.navbar.expanded .navbar-link{width:100%;display:block}}.sidebar{display:flex;flex-direction:column;width:250px;height:100%;background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);padding:var(--spacing-4);transition:width var(--transition-normal);overflow-y:auto}.sidebar.collapsed{width:64px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-6);height:2rem}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar-brand{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-text-primary);white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-brand{display:none}.sidebar-toggle{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--spacing-1);list-style:none;padding:0;margin:0}.sidebar-item{width:100%}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-link{padding:var(--spacing-2);justify-content:center}.sidebar-link:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}.sidebar-link.active{background-color:var(--color-primary-50);color:var(--color-primary-600)}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;flex-shrink:0}.sidebar-text{flex-grow:1}.sidebar.collapsed .sidebar-text{display:none}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;list-style:none;margin:0;padding:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.breadcrumbs-item{display:flex;align-items:center}.breadcrumbs-separator{margin:0 var(--spacing-2);color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center}.breadcrumbs-link{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast);border-radius:var(--radius-sm)}.breadcrumbs-link:hover{color:var(--color-text-primary);text-decoration:underline}.breadcrumbs-item.active .breadcrumbs-link{color:var(--color-text-primary);font-weight:var(--font-weight-medium);pointer-events:none;text-decoration:none}.table-container{width:100%;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-surface)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm);text-align:left}.table th,.table td{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border)}.table th{background-color:var(--color-bg-subtle);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);white-space:nowrap}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background-color:var(--color-neutral-50)}.table-dense th,.table-dense td{padding:var(--spacing-2) var(--spacing-3)}.table-striped tbody tr:nth-child(odd){background-color:var(--color-neutral-50)}.table-striped tbody tr:hover{background-color:var(--color-neutral-100)}.table-sticky-header th{position:sticky;top:0;z-index:1;box-shadow:0 1px 0 var(--color-border)}.table-sort-button{background:none;border:none;cursor:pointer;padding:0;margin-left:var(--spacing-1);color:var(--color-text-tertiary);display:inline-flex;align-items:center}.table-sort-button:hover{color:var(--color-text-primary)}.table-sort-button.active{color:var(--color-primary-600)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.modal-overlay.open{opacity:1;visibility:visible}.modal{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:32rem;max-height:90vh;display:flex;flex-direction:column;transform:scale(.95);transition:transform var(--transition-normal);border:1px solid var(--color-border)}.modal-overlay.open .modal{transform:scale(1)}.modal-header{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:var(--spacing-1);color:var(--color-text-secondary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-6);overflow-y:auto;color:var(--color-text-secondary)}.modal-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border);background-color:var(--color-bg-subtle);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.modal-sm{max-width:24rem}.modal-lg{max-width:48rem}.modal-xl{max-width:64rem}.modal-full{max-width:100%;height:100%;border-radius:0}.tooltip-container{position:relative;display:inline-block}.tooltip{position:absolute;background-color:var(--color-neutral-900);color:#fff;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);white-space:nowrap;z-index:1000;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast);pointer-events:none}.tooltip.visible{opacity:1;visibility:visible}.tooltip-top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--spacing-1)}.tooltip-bottom{top:100%;left:50%;transform:translate(-50%);margin-top:var(--spacing-1)}.tooltip-left{right:100%;top:50%;transform:translateY(-50%);margin-right:var(--spacing-1)}.tooltip-right{left:100%;top:50%;transform:translateY(-50%);margin-left:var(--spacing-1)}.tooltip:after{content:"";position:absolute;border-width:4px;border-style:solid}.tooltip-top:after{top:100%;left:50%;margin-left:-4px;border-color:var(--color-neutral-900) transparent transparent transparent}.tooltip-bottom:after{bottom:100%;left:50%;margin-left:-4px;border-color:transparent transparent var(--color-neutral-900) transparent}.tooltip-left:after{top:50%;left:100%;margin-top:-4px;border-color:transparent transparent transparent var(--color-neutral-900)}.tooltip-right:after{top:50%;right:100%;margin-top:-4px;border-color:transparent var(--color-neutral-900) transparent transparent}.avatar{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;overflow:hidden;-webkit-user-select:none;user-select:none;border-radius:var(--radius-full);background-color:var(--color-neutral-200);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase}.avatar-image{width:100%;height:100%;object-fit:cover;border-radius:inherit}.avatar-sm{width:2rem;height:2rem;font-size:.75rem}.avatar-md{width:2.5rem;height:2.5rem;font-size:1rem}.avatar-lg{width:3rem;height:3rem;font-size:1.25rem}.avatar-xl{width:4rem;height:4rem;font-size:1.5rem}.avatar-circle{border-radius:50%}.avatar-square{border-radius:var(--radius-md)}.avatar-container{position:relative;display:inline-block}.avatar-status{position:absolute;bottom:0;right:0;width:.75rem;height:.75rem;border-radius:50%;border:2px solid var(--color-bg-surface)}.avatar-status-online{background-color:var(--color-success)}.avatar-status-offline{background-color:var(--color-neutral-400)}.avatar-status-busy{background-color:var(--color-error)}.avatar-status-away{background-color:var(--color-warning)}.image-container{position:relative;overflow:hidden;background-color:var(--color-neutral-100);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.image{display:block;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-normal)}.image.loaded{opacity:1}.image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);background-color:var(--color-neutral-100)}.image-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-tertiary);background-color:var(--color-neutral-100);padding:var(--spacing-4);text-align:center;font-size:var(--font-size-sm)}.image-caption{margin-top:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.aspect-ratio-16-9{padding-top:56.25%}.aspect-ratio-4-3{padding-top:75%}.aspect-ratio-1-1{padding-top:100%}.image-container.has-aspect-ratio .image,.image-container.has-aspect-ratio .image-img{position:absolute;top:0;left:0}.image-figure{margin:0;width:100%}.image-img{display:block;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-normal)}.image-img.loaded{opacity:1}.image-placeholder-icon{width:24px;height:24px;color:var(--color-text-tertiary)}.image-error-content{display:flex;flex-direction:column;align-items:center}.image-error-icon{width:24px;height:24px;margin-bottom:var(--spacing-2);color:var(--color-error)}.image-error-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.footer{background-color:var(--color-bg-subtle);border-top:1px solid var(--color-border);padding:var(--spacing-12) 0 var(--spacing-8);color:var(--color-text-primary)}.footer-top{border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-12);margin-bottom:var(--spacing-8)}.footer-newsletter-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-12);align-items:center}.footer-newsletter-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-2);letter-spacing:-.02em}.footer-newsletter-desc{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:480px;line-height:1.6}.footer-newsletter-form{display:flex;gap:var(--spacing-3);width:100%;max-width:420px;justify-self:end}.footer-newsletter-input{flex:1;background-color:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);transition:all var(--transition-fast);height:48px}.footer-newsletter-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 4px var(--color-primary-100)}.footer-newsletter-form .btn{height:48px;border-radius:var(--radius-lg);padding-left:var(--spacing-6);padding-right:var(--spacing-6);font-weight:var(--font-weight-semibold)}.footer-newsletter-input::placeholder{color:var(--color-text-tertiary)}.footer-brand-column{display:flex;flex-direction:column;gap:var(--spacing-6)}.footer-brand-logo{color:var(--color-text-primary)}.footer-brand-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;max-width:320px}@media(max-width:768px){.footer-newsletter-grid{grid-template-columns:1fr!important;gap:var(--spacing-6)}.footer-newsletter-form{justify-self:start;max-width:100%}.footer-brand-desc{max-width:100%}}.footer-main{display:grid;grid-template-columns:2fr repeat(4,1fr);gap:var(--spacing-12);margin-bottom:var(--spacing-12)}.footer-column{display:flex;flex-direction:column}.footer-column-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-6) 0;letter-spacing:.025em;text-transform:uppercase}.footer-column-content{display:flex;flex-direction:column;gap:var(--spacing-4)}.footer-link{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-primary-600)}.footer-bottom{padding-top:var(--spacing-8);border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-6)}.footer-bottom p{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}@container (max-width: 1024px){.footer-main{grid-template-columns:repeat(2,1fr);gap:var(--spacing-10)}.footer-brand-column{grid-column:span 2}}@container (max-width: 768px){.footer{padding:var(--spacing-8) 0 var(--spacing-8)}.footer-main{grid-template-columns:repeat(2,1fr);gap:var(--spacing-8)}.footer-column-title{margin-bottom:var(--spacing-4)}.footer-bottom{flex-direction:column-reverse;align-items:flex-start}}@container (max-width: 640px){.footer-main{grid-template-columns:1fr;gap:var(--spacing-8)}.footer-brand-column{grid-column:auto}}.icons-link{color:var(--color-primary-600)}.icons-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-4);color:var(--color-text-primary)}.icons-grid{margin-bottom:var(--spacing-8)}.icon-item{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2);border-radius:var(--radius-md);cursor:help;transition:background-color .2s}.icon-item:hover{background-color:var(--color-bg-subtle)}.color-section{margin-bottom:var(--spacing-6)}.color-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-6)}.color-swatch{align-items:stretch}.color-swatch-preview{height:80px;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.color-swatch-meta{align-items:flex-start}.color-swatch-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.color-swatch-variable,.color-swatch-hex{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-family:var(--font-family-mono)}.typography-section{margin-bottom:var(--spacing-8)}.typography-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-6)}.typography-row{display:grid;grid-template-columns:200px 1fr;gap:var(--spacing-6);padding:var(--spacing-6) 0;border-bottom:1px solid var(--color-border);align-items:center}.typography-meta{align-items:flex-start}.typography-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.typography-variable{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-family:var(--font-family-mono)}.typography-value{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.typography-sample{color:var(--color-text-primary)}.sample-xs{font-size:var(--font-size-xs)}.sample-sm{font-size:var(--font-size-sm)}.sample-base{font-size:var(--font-size-base)}.sample-lg{font-size:var(--font-size-lg)}.sample-xl{font-size:var(--font-size-xl)}.sample-2xl{font-size:var(--font-size-2xl)}.sample-3xl{font-size:var(--font-size-3xl)}.sample-4xl{font-size:var(--font-size-4xl)}.sample-weight-regular{font-weight:var(--font-weight-regular);font-size:var(--font-size-xl)}.sample-weight-medium{font-weight:var(--font-weight-medium);font-size:var(--font-size-xl)}.sample-weight-semibold{font-weight:var(--font-weight-semibold);font-size:var(--font-size-xl)}.sample-weight-bold{font-weight:var(--font-weight-bold);font-size:var(--font-size-xl)}.sample-family-sans{font-family:var(--font-family-sans);font-size:var(--font-size-xl)}.sample-family-mono{font-family:var(--font-family-mono);font-size:var(--font-size-base)}@media(max-width:768px){.typography-row{grid-template-columns:1fr}}.container-demo{background-color:var(--color-bg-subtle);padding:var(--spacing-4);border-radius:var(--radius-md)}.container-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.banner-demo{width:100%;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border)}.banner-demo-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary-600),var(--color-secondary-500));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff}.banner-demo-brand{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.banner-variants-demo{width:100%}.banner-variants-demo .banner{border-radius:var(--radius-md)}.banner{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-3) 0}.banner-sticky{position:sticky;top:0;z-index:50}.banner-primary{background-color:var(--color-primary-600);border-bottom-color:var(--color-primary-700);color:#fff}.banner-info{background-color:var(--color-info);border-bottom-color:var(--color-info);color:#fff}.banner-warning{background-color:var(--color-warning);border-bottom-color:var(--color-warning);color:var(--color-neutral-900)}.banner-error{background-color:var(--color-error);border-bottom-color:var(--color-error);color:#fff}.banner-inner{flex-wrap:nowrap}.banner-brand{display:flex;align-items:center;gap:var(--spacing-3)}.banner-nav{display:flex;align-items:center;gap:var(--spacing-1)}.banner-actions{display:flex;align-items:center;gap:var(--spacing-3)}.banner-nav-mobile{display:none}@container (max-width: 768px){.banner-nav-desktop{display:none}.banner-nav-mobile{display:block}}.hamburger-menu{position:relative;display:inline-block}.hamburger-button{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);transition:all var(--transition-fast)}.hamburger-button:hover{background-color:var(--color-bg-subtle)}.hamburger-icon{width:24px;height:24px}.hamburger-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-2);min-width:200px;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;padding:var(--spacing-2);animation:fadeIn .2s ease-out}.hamburger-content{display:flex;flex-direction:column;gap:var(--spacing-1)}.hamburger-content a,.hamburger-content button{display:block;width:100%;text-align:left;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;background:transparent;border:none;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.hamburger-content a:hover,.hamburger-content button:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.icon-button{padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.icon-button.button-size-sm{width:32px;height:32px}.icon-button.button-size-md{width:40px;height:40px}.icon-button.button-size-lg{width:48px;height:48px}.icon-button svg{width:1.25em;height:1.25em}.code-block-container{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);background-color:#1e1e1e;margin:var(--spacing-4) 0}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-4);background-color:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1)}.code-language{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.code-copy-btn{color:var(--color-text-secondary)}.code-copy-btn:hover{color:var(--color-text-primary);background-color:#ffffff1a}.markdown-content{font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary)}.markdown-content>*:first-child{margin-top:0}.markdown-content>*:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-top:var(--spacing-6);margin-bottom:var(--spacing-3)}.markdown-content h1{font-size:var(--font-size-3xl)}.markdown-content h2{font-size:var(--font-size-2xl)}.markdown-content h3{font-size:var(--font-size-xl)}.markdown-content h4{font-size:var(--font-size-lg)}.markdown-content p{margin-bottom:var(--spacing-4)}.markdown-content ul,.markdown-content ol{margin-bottom:var(--spacing-4);padding-left:var(--spacing-6)}.markdown-content li{margin-bottom:var(--spacing-1)}.markdown-content blockquote{border-left:4px solid var(--color-primary-200);margin:var(--spacing-4) 0;padding-left:var(--spacing-4);color:var(--color-text-secondary);font-style:italic}.markdown-content code:not(pre code){background-color:var(--color-bg-subtle);padding:.2em .4em;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.875em;color:var(--color-primary-700)}.markdown-link{color:var(--color-primary-600);text-decoration:none;font-weight:var(--font-weight-medium)}.markdown-link:hover{text-decoration:underline}.markdown-table-wrapper{overflow-x:auto;margin-bottom:var(--spacing-4);border-radius:var(--radius-md);border:1px solid var(--color-border)}.markdown-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.markdown-table th,.markdown-table td{padding:var(--spacing-3);text-align:left;border-bottom:1px solid var(--color-border)}.markdown-table th{background-color:var(--color-bg-subtle);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.markdown-table tr:last-child td{border-bottom:none}.skeleton{background-color:var(--color-neutral-200);animation:skeleton-pulse 1.5s ease-in-out .5s infinite}.skeleton-text{margin-top:0;margin-bottom:0;height:1em;width:100%;border-radius:var(--radius-sm)}.skeleton-circular{border-radius:50%}.skeleton-rectangular{border-radius:0}.skeleton-rounded{border-radius:var(--radius-md)}@keyframes skeleton-pulse{0%{opacity:1}50%{opacity:.4}to{opacity:1}}@media(prefers-color-scheme:dark){.skeleton{background-color:var(--color-neutral-800)}}[data-theme=dark] .skeleton{background-color:var(--color-neutral-800)}.progress-container{width:100%;display:flex;align-items:center;gap:var(--spacing-3)}.progress-bar-track{flex:1;background-color:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;transition:width .3s ease;border-radius:var(--radius-full)}.progress-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:3ch;text-align:right}.progress-default{background-color:var(--color-primary-600)}.progress-success{background-color:var(--color-success)}.progress-warning{background-color:var(--color-warning)}.progress-error{background-color:var(--color-error)}.progress-sm .progress-bar-track{height:4px}.progress-md .progress-bar-track{height:8px}.progress-lg .progress-bar-track{height:12px}[data-theme=dark] .progress-bar-track{background-color:var(--color-neutral-700)}.popover-container{position:relative;display:inline-block}.popover-trigger{cursor:pointer;display:inline-block}.popover-content{position:absolute;z-index:100;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-4);min-width:200px;animation:popover-fade-in .15s ease-out}.popover-bottom{top:calc(100% + var(--spacing-2));left:50%;transform:translate(-50%)}.popover-top{bottom:calc(100% + var(--spacing-2));left:50%;transform:translate(-50%)}.popover-left{right:calc(100% + var(--spacing-2));top:50%;transform:translateY(-50%)}.popover-right{left:calc(100% + var(--spacing-2));top:50%;transform:translateY(-50%)}@keyframes popover-fade-in{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.popover-left{animation-name:popover-fade-in-left}.popover-right{animation-name:popover-fade-in-right}@keyframes popover-fade-in-left{0%{opacity:0;transform:translate(10px,-50%)}to{opacity:1;transform:translateY(-50%)}}@keyframes popover-fade-in-right{0%{opacity:0;transform:translate(-10px,-50%)}to{opacity:1;transform:translateY(-50%)}}.dropdown-container{position:relative;display:inline-block}.dropdown-trigger{cursor:pointer;display:inline-block}.dropdown-content{position:absolute;top:calc(100% + var(--spacing-1));z-index:100;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-1);min-width:180px;animation:dropdown-fade-in .1s ease-out}.dropdown-align-left{left:0}.dropdown-align-right{right:0}.dropdown-item{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-2);transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--color-bg-subtle)}.dropdown-divider{height:1px;background-color:var(--color-border);margin:var(--spacing-1) 0}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-8)}.empty-state-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-full);background-color:var(--color-bg-secondary);color:var(--color-text-tertiary);margin-bottom:var(--spacing-4)}.empty-state-icon svg{width:32px;height:32px}.empty-state-title{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.empty-state-description{margin:var(--spacing-2) 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:360px}.empty-state-action{margin-top:var(--spacing-6)}.empty-state-sm{padding:var(--spacing-4)}.empty-state-sm .empty-state-icon{width:48px;height:48px;margin-bottom:var(--spacing-3)}.empty-state-sm .empty-state-icon svg{width:24px;height:24px}.empty-state-sm .empty-state-title{font-size:var(--font-size-base)}.empty-state-sm .empty-state-description{font-size:var(--font-size-xs)}.empty-state-sm .empty-state-action{margin-top:var(--spacing-4)}.empty-state-lg{padding:var(--spacing-12)}.empty-state-lg .empty-state-icon{width:80px;height:80px;margin-bottom:var(--spacing-6)}.empty-state-lg .empty-state-icon svg{width:40px;height:40px}.empty-state-lg .empty-state-title{font-size:var(--font-size-xl)}.empty-state-lg .empty-state-description{font-size:var(--font-size-base);max-width:480px}.empty-state-lg .empty-state-action{margin-top:var(--spacing-8)}.pagination,.pagination-pages{display:flex;align-items:center;gap:var(--spacing-1)}.pagination-button{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s ease}.pagination-button:hover:not(:disabled){background-color:var(--color-bg-secondary);border-color:var(--color-border-hover)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button.active{background-color:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff}.pagination-button.active:hover{background-color:var(--color-primary-700);border-color:var(--color-primary-700)}.pagination-prev svg,.pagination-next svg{width:16px;height:16px}.pagination-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.pagination-sm .pagination-button,.pagination-sm .pagination-ellipsis{min-width:28px;height:28px;font-size:var(--font-size-xs)}.pagination-sm .pagination-prev svg,.pagination-sm .pagination-next svg{width:14px;height:14px}.pagination-lg .pagination-button,.pagination-lg .pagination-ellipsis{min-width:44px;height:44px;font-size:var(--font-size-base)}.pagination-lg .pagination-prev svg,.pagination-lg .pagination-next svg{width:20px;height:20px}.toast-container{position:fixed;z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-3);pointer-events:none;padding:var(--spacing-4)}.toast-top-right{top:0;right:0;align-items:flex-end}.toast-top-left{top:0;left:0;align-items:flex-start}.toast-bottom-right{bottom:0;right:0;align-items:flex-end}.toast-bottom-left{bottom:0;left:0;align-items:flex-start}.toast-top-center{top:0;left:50%;transform:translate(-50%);align-items:center}.toast-bottom-center{bottom:0;left:50%;transform:translate(-50%);align-items:center}.toast{display:flex;align-items:center;gap:var(--spacing-3);min-width:300px;max-width:420px;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);background-color:var(--color-bg-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toast-slide-in .3s ease-out}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-icon svg{width:20px;height:20px}.toast-message{flex:1;margin:0;font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.4}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all .15s ease}.toast-close:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.toast-close svg{width:16px;height:16px}.toast-success{border-left:4px solid var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-left:4px solid var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}.app-shell{display:flex;flex-direction:column;height:100%;min-height:100%;--app-shell-sidebar-width: 260px;--app-shell-sidebar-collapsed-width: 64px;--app-shell-navbar-height: 60px}.app-shell.navbar-fixed,.app-shell.sidebar-fixed{min-height:100vh}.app-shell-navbar{display:flex;align-items:center;height:var(--app-shell-navbar-height);background-color:var(--color-bg-surface);z-index:100}.app-shell-navbar>*:not(.app-shell-menu-toggle){flex:1}.navbar-fixed .app-shell-navbar{position:fixed;top:0;left:0;right:0}.navbar-fixed .app-shell-body{padding-top:var(--app-shell-navbar-height)}.app-shell-menu-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;margin-left:var(--spacing-2);padding:0;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-primary);cursor:pointer;transition:background-color .15s ease}.app-shell-menu-toggle:hover{background-color:var(--color-bg-secondary)}.app-shell-menu-toggle svg{width:24px;height:24px}.app-shell-body{display:flex;flex:1}.app-shell-sidebar{flex-shrink:0;background-color:var(--color-bg-surface);transition:width var(--transition-normal)}.sidebar-fixed .app-shell-sidebar{position:fixed;top:var(--app-shell-navbar-height);left:0;bottom:0;z-index:50}.sidebar-fixed.navbar-fixed .app-shell-sidebar{top:var(--app-shell-navbar-height)}.sidebar-fixed:not(.navbar-fixed) .app-shell-sidebar{top:0}.app-shell-main{flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition-normal)}.sidebar-fixed .app-shell-main{margin-left:var(--app-shell-sidebar-width)}.sidebar-fixed .app-shell-sidebar:has(.sidebar.collapsed)~.app-shell-main{margin-left:var(--app-shell-sidebar-collapsed-width)}.app-shell-content{flex:1}.app-shell-footer{margin-top:auto}.app-shell-overlay{display:none}@media(max-width:768px){.app-shell-menu-toggle{display:flex}.app-shell-sidebar{position:fixed;top:var(--app-shell-navbar-height);left:0;bottom:0;transform:translate(-100%);transition:transform .3s ease;z-index:200}.navbar-fixed .app-shell-sidebar{top:var(--app-shell-navbar-height)}.app-shell-sidebar.open{transform:translate(0)}.sidebar-fixed .app-shell-main{margin-left:0}.app-shell-overlay{display:block;position:fixed;inset:0;top:var(--app-shell-navbar-height);background-color:#00000080;z-index:150}}.example-layout{display:flex;flex-direction:column;gap:var(--spacing-6);height:100%}.example-layout-content{display:grid;grid-template-columns:1fr 250px;gap:var(--spacing-8);align-items:start}.example-preview{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-6);overflow:hidden}.example-preview.no-padding{padding:0}.example-sidebar{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-4);position:sticky;top:var(--spacing-6)}.example-sidebar-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-3)}.used-components-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.used-component-link{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);text-decoration:none;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.used-component-link:hover{background-color:var(--color-bg-subtle);border-color:var(--color-border-hover);transform:translateY(-1px)}.link-icon{width:16px;height:16px;color:var(--color-text-tertiary)}.used-component-link:hover .link-icon{color:var(--color-primary-500)}@media(max-width:1024px){.example-layout-content{grid-template-columns:1fr}.example-sidebar{position:static}}.chat-bubble-container{display:flex;gap:var(--spacing-3);max-width:80%;margin-bottom:var(--spacing-4)}.chat-bubble-container.user{margin-left:auto;flex-direction:row-reverse}.chat-bubble-container.ai{margin-right:auto}.chat-avatar{width:32px;height:32px;border-radius:var(--radius-full);background-color:var(--color-bg-subtle);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--color-border);color:var(--color-text-secondary)}.chat-bubble-content{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:0}.chat-bubble-message{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);font-size:var(--font-size-base);line-height:1.5;position:relative}.chat-bubble-container.user .chat-bubble-message{background-color:var(--color-primary-600);color:#fff;border-bottom-right-radius:var(--radius-sm)}.chat-bubble-container.ai .chat-bubble-message{background-color:var(--color-bg-subtle);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm);border:1px solid var(--color-border)}.chat-bubble-container.error .chat-bubble-message{background-color:var(--color-error);background-color:#fef2f2;color:var(--color-error);border:1px solid var(--color-error)}[data-theme=dark] .chat-bubble-container.error .chat-bubble-message{background-color:#450a0a}.chat-timestamp{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.chat-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-1);opacity:0;transition:opacity var(--transition-fast)}.chat-bubble-container:hover .chat-actions{opacity:1}.chat-action-btn{background:transparent;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.chat-action-btn:hover{color:var(--color-text-primary);background-color:var(--color-bg-subtle)}.thinking-dots{display:flex;gap:4px;padding:var(--spacing-1) 0}.thinking-dot{width:6px;height:6px;background-color:currentColor;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both;opacity:.6}.thinking-dot:nth-child(1){animation-delay:-.32s}.thinking-dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-container{display:flex;align-items:flex-end;gap:var(--spacing-2);padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);background-color:var(--color-bg-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.chat-input-container:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.chat-input-wrapper{flex:1;min-width:0}.chat-input-field-override{min-height:24px;max-height:200px;resize:none;padding:var(--spacing-2) 0;border:none!important;background:transparent!important;box-shadow:none!important;outline:none!important}.chat-input-field-override:focus{box-shadow:none!important}.chat-input-wrapper .textarea-wrapper{margin-bottom:0;width:100%}.chat-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);border:none;background-color:var(--color-bg-subtle);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;padding:0}.chat-action-btn:hover:not(:disabled){background-color:var(--color-bg-default);color:var(--color-text-primary)}.chat-send-btn-override{width:36px!important;height:36px!important;border-radius:var(--radius-full)!important;flex-shrink:0}.chat-send-btn-override:disabled{opacity:.5;cursor:not-allowed}.chat-container{height:calc(100vh - 140px);min-height:500px;display:flex;flex-direction:column;padding:0;overflow:hidden;background-color:var(--color-bg-surface)}.chat-header{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-surface)}.chat-messages{flex:1;padding:var(--spacing-4);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-4);background-color:var(--color-bg-surface)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-secondary);gap:var(--spacing-4)}.empty-state h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.chat-input-wrapper{padding:var(--spacing-4);border-top:1px solid var(--color-border)}.chat-bubble .markdown-body{font-size:var(--font-size-md)}.chat-bubble .markdown-body p{margin-bottom:var(--spacing-2)}.chat-bubble .markdown-body p:last-child{margin-bottom:0}.viewport-content .chat-container{border:none;border-radius:var(--radius-lg);height:100%}.product-layout-demo{display:flex;flex-direction:column;min-height:800px;width:100%;background-color:var(--color-bg-default);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border)}.demo-header-inner{flex-wrap:nowrap}.demo-logo{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary-600),var(--color-secondary-500));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff}.demo-brand{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.demo-nav{flex-wrap:nowrap}.demo-nav-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.demo-nav-item:hover{color:var(--color-text-primary);background-color:var(--color-bg-subtle)}.demo-nav-item.active{color:var(--color-primary-600);background-color:var(--color-primary-50)}.demo-icon-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.demo-icon-btn:hover{color:var(--color-text-primary);background-color:var(--color-bg-subtle)}.demo-notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background-color:var(--color-error);border-radius:50%;border:2px solid var(--color-bg-surface)}.demo-main{flex:1;padding:var(--spacing-8) 0;background-color:var(--color-bg-subtle)}.demo-page-header{margin-bottom:var(--spacing-8)}.demo-page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.demo-page-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.demo-stats-grid{margin-bottom:var(--spacing-8)}.demo-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.demo-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.demo-stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary-50);border-radius:var(--radius-lg)}.demo-split-view{margin-bottom:var(--spacing-8)}.demo-activity-item{padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.demo-activity-item:last-child{padding-bottom:0;border-bottom:none}.demo-activity-content{flex:1}.demo-activity-text{font-size:var(--font-size-sm);color:var(--color-text-primary)}.demo-activity-text strong{font-weight:var(--font-weight-semibold)}.demo-activity-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.demo-task-item{padding:var(--spacing-3);background-color:var(--color-bg-subtle);border-radius:var(--radius-md)}.demo-task-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.demo-task-due{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.demo-footer-grid{margin-bottom:var(--spacing-6)}@media(max-width:768px){.demo-nav{display:none}.demo-page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-4)}}.viewport-content .product-layout-demo{border:none;border-radius:var(--radius-lg);min-height:100%}
