.article-page{max-width:1200px;margin:0 auto;border:0;border-left:1px solid var(--border-primary);border-right:1px solid var(--border-primary);background-color:var(--bg-primary)}.post{padding:var(--space-3xl);background-color:var(--bg-primary);color:var(--text-primary)}.pwa-logo{margin-right:5px;height:17px;width:45px}img{width:100%}h3{border:none;font-size:var(--font-size-heading);margin:.75rem 0;padding:0;width:-webkit-fit-content;width:fit-content;z-index:0;color:var(--text-heading)}.top-items{margin:0 auto}.announce{background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-md);font-size:var(--font-size-lg);border-left:4px solid var(--border-focus)}#close{height:25px;width:25px;text-align:center;float:right;border-radius:50%;margin-bottom:5px;font-size:var(--font-size-xl)!important}#close:hover{display:inline-block;color:#fff}figure{margin:0 auto}figcaption{background:var(--bg-secondary);color:var(--text-secondary);text-align:center;padding:var(--space-xs);font-size:var(--font-size-base)}.article-section{width:100%;padding:5px;box-sizing:border-box;top:0;right:0;left:0;overflow-y:auto}.fix{margin:60px auto}.quote{background-color:var(--bg-secondary);padding:var(--space-md);font-size:var(--font-size-md);margin:var(--space-lg) auto;border-radius:var(--radius-md);border:1px solid var(--border-primary);color:var(--text-secondary)}.highlight{background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-md);font-size:var(--font-size-md);border-left:4px solid var(--border-focus)}.highlight a{color:#00796b!important;text-decoration:underline}.date{display:flex;align-items:center;flex-direction:row;justify-content:space-between}.date-text{text-transform:uppercase;background:linear-gradient(141.27deg,#ff904e -4.24%,#ff5982 21.25%,#ec68f4 44.33%,#79e2ff 83.46%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.1rem;font-size:var(--font-size-base);font-weight:600}.navigation{margin:0 auto;width:100px;text-align:center;border-bottom:1px solid var(--blue-color);padding-bottom:7px}.bold{border-left:3px solid var(--blue-color);padding-left:10px;color:var(--blue-color)}.cut{text-decoration:line-through}#progress{position:absolute;background:var(--blue-color);height:100vh;width:0;transition:width .2s ease-in-out}.center{height:100vh;display:flex;justify-content:center;align-items:center}table{width:100%;border-collapse:collapse;margin:var(--space-lg) auto;font-size:var(--font-size-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden}thead tr{background-color:var(--bg-secondary)}th{text-align:left;padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-weight:600;border-bottom:1px solid var(--border-primary)}td{padding:var(--space-sm) var(--space-md);color:var(--text-primary);border-bottom:1px solid var(--border-primary)}tbody tr:last-child td{border-bottom:none}td:first-child{font-family:monospace;font-size:var(--font-size-base);color:var(--text-heading)}@media (min-width: 800px){.article-section{top:0;bottom:0}}code[class*=language-],pre[class*=language-]{color:var(--text-primary);background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:var(--font-size-md);text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;-moz-tab-size:4;tab-size:4;-webkit-hyphens:none;hyphens:none}pre[class*=language-]::selection,pre[class*=language-] ::selection,code[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;background:var(--bg-tertiary)}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}pre[class*=language-]{padding:var(--space-lg);margin:var(--space-lg) 0;overflow:auto;border-radius:var(--radius-md);border:1px solid var(--border-primary)}:not(pre)>code[class*=language-],pre[class*=language-]{background:var(--bg-secondary)}:not(pre)>code[class*=language-]{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);white-space:normal;background:var(--bg-secondary);border:1px solid var(--border-primary)}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:var(--color-gray-lightest)}.token.punctuation{color:var(--color-white-dark)}.namespace{opacity:.7}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:var(--color-orange)}.token.boolean,.token.number{color:var(--color-green)}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:var(--color-pink)}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:var(--color-white-dark)}.token.atrule,.token.attr-value,.token.keyword{color:var(--color-blue)}.token.function,.token.class-name{color:var(--color-orange)}.token.regex,.token.important,.token.variable{color:var(--color-green)}.token.important,.token.bold{font-weight:var(--font-weight-bold)}.token.italic{font-style:italic}.token.entity{cursor:help}.header-console-btn{cursor:pointer;border:1px solid var(--color-gray-lightest);padding:3px 6px;border-radius:3px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:var(--font-size-sm);text-transform:uppercase;font-weight:600;background:var(--color-gray-darker);color:var(--color-white);text-decoration:none}.header-console-btn:hover{color:var(--color-white);border-color:var(--color-white);background:var(--color-black);text-decoration:none}.header-console-btn:active{background:var(--color-black);opacity:.8}.header-playground-btn{background:#455a64;border-color:#455a64}.header-playground-btn:hover{background:#37474f;border-color:#37474f}.header-cta-group{display:flex;align-items:center;gap:6px}.header-search-btn{position:relative}.header-kbd{padding:2px 4px;font-size:.65rem;font-family:monospace;border:1px solid var(--color-gray-lightest);border-radius:2px;background:var(--color-black);opacity:.7}@media (max-width: 768px){.header-kbd,.header-console-btn span{display:none}}.sidebar{height:100vh;overflow:auto}.sidebar-inner{height:100%;position:fixed;width:100%;max-width:300px;background-color:var(--bg-primary);box-sizing:border-box;border:0;border-right:1px solid var(--border-secondary);z-index:var(--z-sidebar);overflow-y:auto}.sidebar-title{border:0;border-top:1px solid var(--border-secondary);cursor:pointer;display:flex;align-items:center;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);box-sizing:border-box;background:var(--bg-primary);transition:color var(--transition-normal);color:var(--text-muted)}.sidebar-title:hover{color:var(--text-primary)}.sidebar-title-left{width:100%;color:inherit}.sidebar-title-right{float:right;display:flex;align-items:center;color:var(--color-gray-lightest)}.sidebar-intro-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-right:var(--space-lg)}.sidebar-intro-row .sidebar-nav-item{flex:1}.sidebar-search-btn{cursor:pointer;border:1px solid var(--border-primary);border-radius:3px;background:var(--bg-primary);color:var(--text-secondary);padding:.25rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.sidebar-search-btn:hover{background:var(--bg-secondary);color:var(--text-heading);border-color:var(--border-focus)}.sidebar-search-btn:active{opacity:.8}.sidebar-nav-item-container{overflow-y:auto;height:calc(100vh - 185px);background:var(--bg-primary)}.sidebar-nav-item{border:0;cursor:pointer;display:flex;align-items:center;padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);box-sizing:border-box;transition:all var(--transition-fast);color:var(--text-tertiary);border-left:2px solid transparent;text-decoration:none}.sidebar-nav-item:hover{color:var(--text-primary);border-left-color:var(--border-focus);background-color:var(--bg-hover);text-decoration:none}.sidebar-nav-item.active{color:var(--text-primary);background-color:var(--bg-secondary);border-left-color:var(--border-focus);font-weight:var(--font-weight-medium);text-decoration:none}.sidebar-nav-item-text{margin-left:var(--space-sm)}.sidebar-info{padding:var(--space-md) var(--space-lg);font-size:var(--font-size-sm);-webkit-user-select:text;user-select:text;background:var(--bg-primary);border-top:1px solid var(--border-secondary)}.sidebar-info-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin:var(--space-md) 0 var(--space-sm) 0;color:var(--text-muted)}.sidebar-info-title:first-child{margin-top:0}.sidebar-info-text{font-size:var(--font-size-sm);color:var(--color-gray-lightest)}.sidebar-info-text p{margin:var(--space-sm) 0}.sidebar-info-text a{color:var(--text-tertiary);text-decoration:none;font-weight:var(--font-weight-normal);border-bottom:none;transition:color var(--transition-fast)}.sidebar-info-text a:hover{color:var(--text-primary)}.sidebar-info ul{margin:0;padding:0;padding-left:var(--space-md)}@media only screen and (max-width: 736px){.sidebar{display:none}}.app-share-icon{cursor:pointer;border:1px solid var(--color-gray-lightest);padding:3px 6px;border-radius:3px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:var(--font-size-sm);background:var(--color-gray-darker);color:var(--color-white)}.app-share-icon:hover{color:var(--color-white);border-color:var(--color-white);background:var(--color-black)}.app-share-icon:active{background:var(--color-black);opacity:.8}.code-block-wrapper{position:relative;margin:1rem 0}.code-block{margin:0}.code-copy-btn{position:absolute;top:8px;right:8px;background:transparent;border:none;border-radius:3px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-gray-lightest)}.code-copy-btn:hover{background:var(--color-gray-darker);color:var(--color-white)}.code-copy-btn:active{background:var(--color-black)}.timeline-sections{margin:1rem 0}.collapsible-section{margin-bottom:1rem}.collapsible-summary{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;transition:background .15s ease}.collapsible-summary:hover{background:var(--bg-secondary)}.collapsible-section[open] .collapsible-summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.collapsible-summary::-webkit-details-marker{display:none}.collapsible-heading{margin:0!important;font-size:.95rem!important;font-weight:600!important;color:var(--text-heading)!important}.collapsible-icon{flex-shrink:0;margin-left:1rem;color:var(--text-secondary);transition:transform .15s ease}.collapsible-section[open] .collapsible-icon{transform:rotate(180deg)}.collapsible-content{padding:1rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-top:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.collapsible-content>*:first-child{margin-top:0}.collapsible-content>*:last-child{margin-bottom:0}.collapsible-summary:focus-visible{outline:2px solid var(--border-primary);outline-offset:2px}@media (max-width: 768px){.collapsible-summary{padding:.75rem .875rem}.collapsible-content{padding:.875rem}.collapsible-heading{font-size:.9rem!important}}.tabbed-content{margin:1.5rem 0}.tabs-header{background:transparent;padding:0 0 1rem}.tabs-list{display:inline-flex;border:1px solid var(--border-primary);border-radius:3px;overflow:hidden}.tab-button{padding:.5rem 1rem;border:none;border-right:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.tab-button:last-child{border-right:none}.tab-button:hover:not(.active){background:var(--bg-secondary)}.tab-button.active{background:var(--text-heading);color:var(--bg-primary)}.tab-button:focus-visible{outline:2px solid var(--text-heading);outline-offset:-2px;z-index:1}.tabs-panels{padding:0}.tab-panel>*:first-child{margin-top:0}.tab-panel>*:last-child{margin-bottom:0}@media (max-width: 768px){.tab-button{padding:.4rem .875rem;font-size:.75rem}}.command-palette-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:9999;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.command-palette{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;width:90%;max-width:640px;max-height:60vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #0000004d;animation:slideDown .2s ease}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.command-palette-header{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border-primary)}.command-palette-header svg{color:var(--text-secondary);flex-shrink:0}.command-palette-input{flex:1;border:none;background:transparent;color:var(--text-heading);font-size:1rem;outline:none}.command-palette-input::placeholder{color:var(--text-secondary)}.command-palette-kbd{padding:.25rem .5rem;border:1px solid var(--border-primary);border-radius:3px;font-size:.75rem;color:var(--text-secondary);font-family:monospace;background:var(--bg-secondary)}.command-palette-results{overflow-y:auto;max-height:400px;padding:.5rem}.command-palette-item{padding:.75rem;cursor:pointer;border-radius:4px;margin-bottom:.25rem;transition:background .1s ease}.command-palette-item:hover,.command-palette-item.selected{background:var(--bg-secondary)}.command-palette-item-title{color:var(--text-heading);font-weight:500;font-size:.9rem;margin-bottom:.25rem}.command-palette-item-blurb{color:var(--text-secondary);font-size:.8rem;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.command-palette-empty{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.command-palette-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border-primary);font-size:.75rem;color:var(--text-secondary)}.command-palette-footer span{display:flex;align-items:center;gap:.5rem}.command-palette-footer kbd{padding:.125rem .375rem;border:1px solid var(--border-primary);border-radius:3px;font-family:monospace;background:var(--bg-secondary);font-size:.7rem}@media (max-width: 768px){.command-palette-overlay{padding-top:10vh}.command-palette{width:95%;max-height:70vh}.command-palette-footer{display:none}.command-palette-item-blurb{font-size:.75rem}}body{margin:0;font-size:var(--font-size-md);font-family:Graphik LCG Web,Graphik Arabic Web Regular,-apple-system,BlinkMacSystemFont,Helvetica Neue,Helvetica,Arial,Lucida Grande,Sans-Serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}html{--color-black: #000;--color-gray-darkest: #111;--color-gray-darker: #1a1a1a;--color-gray-dark: #222;--color-gray-medium: #2a2a2a;--color-gray: #333;--color-gray-light: #444;--color-gray-lighter: #555;--color-gray-lightest: #666;--color-white-darkest: #888;--color-white-darker: #999;--color-white-dark: #aaa;--color-white-medium: #ccc;--color-white-light: #e5e5e5;--color-white: #fff;--color-pink: #ff6b9d;--color-orange: #ff9800;--color-blue-light: #64b5f6;--color-blue: #42a5f5;--color-blue-dark: #2196f3;--color-green-light: #81c784;--color-green: #66bb6a;--color-green-dark: #4caf50;--bg-primary: var(--color-black);--bg-secondary: var(--color-gray-darker);--bg-tertiary: var(--color-gray-medium);--bg-hover: var(--color-gray-darkest);--bg-card: var(--color-gray-dark);--text-primary: var(--color-white);--text-secondary: var(--color-white-light);--text-tertiary: var(--color-white-dark);--text-muted: var(--color-white-darkest);--text-heading: var(--color-white);--text-link: var(--color-white);--border-primary: var(--color-gray);--border-secondary: var(--color-gray-dark);--border-hover: var(--color-gray-light);--border-focus: var(--color-white);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 30px;--font-size-xs: .625rem;--font-size-sm: .6875rem;--font-size-base: .8125rem;--font-size-md: .8125rem;--font-size-lg: .875rem;--font-size-xl: .9375rem;--font-size-2xl: 1rem;--font-size-3xl: 1.125rem;--font-size-heading: 1.1rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 4px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 8px rgba(0, 0, 0, .5);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-sidebar: 999;--primary-background-color: var(--bg-primary);--primary-text-color: var(--text-primary);--border-color: var(--border-primary);--card-background-color: var(--bg-card);--color-text-secondary: var(--text-secondary);line-height:1.5;scroll-behavior:smooth;background-color:var(--bg-primary);color:var(--text-primary)}html,body,main{height:100%}a{color:var(--text-link);text-decoration:underline;font-weight:var(--font-weight-semibold);transition:color var(--transition-fast)}a:hover{color:var(--color-pink)}.sub-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.flex-box{display:flex;align-items:center}.tag-label{display:inline-flex;background-color:var(--bg-secondary);align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);color:var(--text-heading);border:1px solid var(--border-primary);flex-direction:row;justify-content:center;box-sizing:border-box;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-lg)}.ai-badge{display:inline-flex;align-items:center;background-color:var(--color-gray);color:var(--color-white);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 6px;margin-left:4px;vertical-align:middle}.recommended-badge{display:inline-flex;align-items:center;background-color:#ec4899;color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 6px;margin-left:4px;vertical-align:middle}.flex-1{display:flex;align-items:center;gap:8px}.advert img{margin-left:-8px;margin-top:5px;width:150px}main{height:100%;margin:0 auto}header{background-color:var(--bg-primary);color:var(--text-secondary);letter-spacing:1px;margin:0 auto;position:-webkit-sticky;position:sticky;border-bottom:1px solid var(--border-primary);top:0;z-index:var(--z-sticky)}.info{display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);color:var(--text-primary);padding:var(--space-xs) var(--space-lg);font-size:var(--font-size-xs)}.audio-intro{border:1px solid var(--border-primary);border-radius:var(--radius-lg);background-color:var(--bg-secondary);padding:var(--space-sm);display:flex;align-items:flex-start;flex-direction:column;gap:var(--space-md);font-size:var(--font-size-sm)}.audio-intro figcaption{font-size:var(--font-size-sm);border-radius:var(--radius-lg);padding:var(--space-xs) var(--space-sm)}.audio-intro audio{height:40px}nav{padding:var(--space-sm) var(--space-xl);margin:0 auto;align-items:center;display:flex}h1{margin:0 auto;font-size:3.125rem;font-weight:700}h2{color:var(--text-secondary)}.nav-title{cursor:pointer;display:flex;align-items:center;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);width:180px}.nav-right{display:flex;align-items:center;justify-content:flex-end;flex:1}.nav-right-inner{float:right;display:flex;align-items:center}.nav-item{display:flex;font-size:var(--font-size-base);align-items:center;font-weight:600}.top-section{padding-bottom:0;text-align:center;height:100%}.logo{margin:0 auto;width:50px}.main-page{height:100%}.docs{margin:0 auto}.test-image{max-width:500px;width:100%}.nav-link{padding:6px 8px;border-radius:3px}.nav-link:hover{color:var(--color-white);background:var(--color-gray-darker)}.home-page{height:100%}.home-page-blurb{display:flex;align-items:center;flex-direction:column;justify-content:center;height:100%;position:fixed;top:0;left:0;right:0;bottom:0}.home-page-blurb-img{width:150px;margin:15px 0}.home-page-blurb-title{background:var(--bg-secondary);font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);text-align:center;padding:var(--space-lg) var(--space-xl)}.home-page-blurb-desc{text-align:center;color:var(--text-secondary);font-size:var(--font-size-3xl);margin:var(--space-lg) 0;font-weight:var(--font-weight-medium)}.nav-active{color:var(--green-color)}.docs-flex{display:flex;flex-direction:row;margin:0 auto;width:100%}.docs-flex-left{max-width:300px;width:100%}.docs-flex-right{box-sizing:border-box;width:100%}.footer{font-weight:600;margin:0 auto;padding:15px 20px;text-align:center}.footer a{border-bottom:2px solid;padding-bottom:3px}.hide-mobile,.nav-icon{display:none}.title-blurb{display:flex;align-items:center;flex-direction:column;padding:20px;box-sizing:border-box}@media only screen and (max-width: 738px){.nav-icon{display:flex}.flex{display:none}.docs{display:block}.post{margin:0 auto;padding:20px!important}.nav-right-inner{display:flex!important;visibility:visible!important}.info{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm)}nav{padding:var(--space-sm) var(--space-md)}}@media (min-width: 800px){.home-page-blurb-title{font-size:40px}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{border-radius:10px}::-webkit-scrollbar-thumb{border-radius:10px;background:var(--scrollbar-background-color)}::-webkit-scrollbar-thumb:window-inactive{background:none}}
