:root{--font-stack: "Cairo", "Noto Sans Arabic", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-stack--monospace: "JetBrains Mono", "Fira Code", "SFMono-Regular", Menlo, Consolas, Monaco, "Liberation Mono", "Lucida Console", monospace;--font-stack--headings: "Cairo", "Noto Sans Arabic", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size--normal: 14px;--font-size--small: 12px;--font-size--small--2: 11px;--font-size--small--3: 10px;--font-size--small--4: 8.5px;--body-font-size: 14px;--body-line-height: 22px;--body-letter-spacing: .02em;--sidebar-caption-font-size: var(--font-size--normal);--sidebar-item-font-size: var(--font-size--normal);--code-font-size: var(--font-size--normal);--header-height: 4rem;--sidebar-item-line-height: 1.2rem;--sidebar-item-spacing-vertical: .75rem;--sidebar-item-spacing-horizontal: 1.25rem;--sidebar-item-height: calc(var(--sidebar-item-line-height) + var(--sidebar-item-spacing-vertical) * 2);--color-foreground-primary: #000000;--color-foreground-secondary: #333333;--color-foreground-muted: #666666;--color-foreground-border: #2D4A41;--color-background-primary: #FFFFFF;--color-background-secondary: #F5F5F5;--color-background-hover: #E8F0ED;--color-background-border: #2D4A41;--color-brand-primary: #000000;--color-brand-primary-rgb: 0, 0, 0;--color-brand-content: #CE1126;--color-accent: #CE1126;--color-success: #2D4A41;--color-warning: #FFA500;--color-error: #CE1126;--color-black: #000000;--btn-1-color: #FFFFFF;--btn-1-bg: #000000;--btn-1-border: #000000;--btn-1-color-hover: #FFFFFF;--btn-1-bg-hover: #CE1126;--btn-1-border-hover: #CE1126;--color-sidebar-background: var(--color-background-primary);--color-sidebar-background-border: var(--color-background-border);--color-sidebar-brand-text: var(--color-foreground-primary);--color-sidebar-caption-text: var(--color-foreground-muted);--color-sidebar-link-text: var(--color-foreground-secondary);--color-sidebar-link-text--top-level: var(--color-brand-primary);--color-sidebar-item-background--hover: var(--color-background-hover);--color-header-background: var(--color-background-primary);--color-header-border: var(--color-background-border);--color-header-text: var(--color-foreground-primary);--color-code-background: #FFFFFF;--color-code-foreground: #000000;--color-inline-code-background: #E8F5E9;--color-link: #CE1126;--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);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem}@media(prefers-color-scheme:dark){html:not([data-theme=dark])[data-theme=light],html:not([data-theme=dark]):not([data-theme]){--color-background-primary: #FFFFFF;--color-background-secondary: #F5F5F5;--color-background-hover: #E8F0ED;--color-background-border: #2D4A41;--color-foreground-primary: #000000;--color-foreground-secondary: #333333;--color-foreground-muted: #666666;--color-foreground-border: #2D4A41;--color-brand-primary: #000000;--color-brand-primary-rgb: 0, 0, 0;--color-brand-content: #CE1126;--color-code-background: #FFFFFF;--color-code-foreground: #000000;--color-sidebar-background: var(--color-background-secondary);--color-sidebar-background-border: var(--color-background-border);--color-sidebar-brand-text: var(--color-foreground-primary);--color-sidebar-caption-text: var(--color-foreground-muted);--color-sidebar-link-text: var(--color-foreground-secondary);--color-sidebar-link-text--top-level: var(--color-brand-primary);--color-sidebar-item-background--hover: linear-gradient(90deg, var(--color-background-hover) 0%, var(--color-background-hover) var(--sidebar-item-spacing-horizontal), var(--color-background-hover) 100%);--color-header-background: var(--color-background-primary);--color-header-border: var(--color-background-border);--color-header-text: var(--color-foreground-primary);--color-inline-code-background: var(--color-background-secondary);--color-link: var(--color-brand-content)}}html[data-theme=dark]{--color-foreground-primary: #FFFFFF;--color-foreground-secondary: #CCCCCC;--color-foreground-muted: #999999;--color-foreground-border: #2D4A41;--color-background-primary: #000000;--color-background-secondary: #1a1a1a;--color-background-hover: #1a2e28;--color-background-border: #2D4A41;--color-brand-primary: #CE1126;--color-brand-primary-rgb: 206, 17, 38;--color-brand-content: #CE1126;--color-accent: #CE1126;--color-success: #2D4A41;--color-warning: #FFA500;--color-error: #CE1126;--color-code-background: #000000;--color-code-foreground: #FFFFFF;--color-sidebar-background: var(--color-background-secondary);--color-sidebar-background-border: var(--color-background-border);--color-sidebar-brand-text: var(--color-foreground-primary);--color-sidebar-caption-text: var(--color-foreground-muted);--color-sidebar-link-text: var(--color-foreground-secondary);--color-sidebar-link-text--top-level: var(--color-brand-primary);--color-sidebar-item-background--hover: linear-gradient(90deg, var(--color-background-hover) 0%, var(--color-background-hover) var(--sidebar-item-spacing-horizontal), var(--color-background-hover) 100%);--color-header-background: var(--color-background-primary);--color-header-border: var(--color-background-border);--color-header-text: var(--color-foreground-primary);--color-inline-code-background: var(--color-background-secondary);--color-link: var(--color-brand-content)}html[data-theme=dark] .mobile-header{background-color:#0f172af2;backdrop-filter:blur(12px);border-bottom:1px solid var(--color-background-border)}*{margin:0;padding:0;box-sizing:border-box}html{background:var(--color-background-primary)!important;min-height:100%;overflow-y:auto}.page,.main,.content,.article-container,.tab-content,.content-section{background:var(--color-background-primary)!important}html,body{min-height:100%;background:var(--color-background-primary)!important;color:var(--color-foreground-primary)}body{font-family:var(--font-stack);font-size:var(--body-font-size);line-height:var(--body-line-height);letter-spacing:var(--body-letter-spacing);margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-background-primary)!important;overflow-x:hidden;overflow-y:auto;max-width:100vw}.table-container{margin:1.5rem 0;overflow-x:auto;border-radius:0;box-shadow:none;border:1px solid var(--color-background-border)}.content-table{width:100%;border-collapse:collapse;background-color:var(--color-background-primary);font-size:var(--font-size--small);line-height:1.5}.content-table thead{background-color:var(--color-background-secondary);border-bottom:1px solid var(--color-background-border)}.content-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-foreground-primary);border-bottom:1px solid var(--color-background-border);white-space:nowrap}.content-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-background-border);color:var(--color-foreground-secondary);vertical-align:top}.content-table tbody tr:hover{background-color:var(--color-background-hover)}.content-table tbody tr:last-child td{border-bottom:none}.content-table code{background-color:var(--color-inline-code-background);padding:.125rem .25rem;border-radius:var(--radius-sm);font-family:var(--font-stack--monospace);font-size:var(--font-size--small--2)}.content-table pre{margin:0;padding:.5rem;background-color:var(--color-code-background);border-radius:var(--radius-sm);overflow-x:auto;font-size:var(--font-size--small--2)}.content-table pre code{background:none;padding:0;border-radius:0}@media(max-width:67em){.table-container{margin:1rem 0}.content-table{font-size:var(--font-size--small--2)}.content-table th,.content-table td{padding:.5rem .75rem}}@media(max-width:48em){.content-table th,.content-table td{padding:.375rem .5rem}.content-table pre{padding:.375rem;font-size:var(--font-size--small--3)}}.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.page{display:flex;flex-direction:column;min-height:100%;overflow-x:hidden;max-width:100vw}.mobile-header{background-color:var(--color-background-primary);backdrop-filter:none;border-bottom:1px solid var(--color-background-border);color:var(--color-header-text);display:flex;height:var(--header-height);width:100%;z-index:1000;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;box-shadow:none;transition:transform .3s ease;transform:translateY(0)}.mobile-header.visible{transform:translateY(0)}.mobile-header .header-left,.mobile-header .header-right{display:flex;height:var(--header-height);padding:0 1rem;align-items:center}.mobile-header .header-center{flex:1;display:flex;justify-content:center;align-items:center;min-width:0}.mobile-header .brand{font-size:1.2rem;font-weight:700;color:var(--color-header-text)}.mobile-header .icon{font-size:1.5em}.header-navigation{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.header-nav-link{color:var(--color-foreground-primary);text-decoration:none;padding:.75rem 1rem;border-radius:0;font-size:16px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;line-height:22px;transition:all ease .3s;position:relative}.header-nav-link:hover{color:var(--color-foreground-primary);text-decoration:underline}.search-container-header{display:flex;align-items:center;margin-right:1rem;position:relative}.search-input-header{width:240px;min-width:120px;padding:.75rem 1rem;border:1px solid var(--color-background-border);border-radius:0;background-color:var(--color-background-primary);color:var(--color-foreground-primary);font-size:14px;letter-spacing:.02em;transition:border-color .2s ease,background-color .2s ease;box-sizing:border-box;box-shadow:none;font-family:var(--font-stack)}.search-input-header:focus{outline:none;border-color:var(--color-foreground-primary);background-color:var(--color-background-primary)}.search-input-header::placeholder{color:var(--color-foreground-secondary)}.search-results{position:absolute;top:100%;right:0;width:100%;max-width:min(400px,calc(100vw - 2rem));max-height:500px;background-color:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;box-shadow:none;z-index:1000;overflow-y:auto;overflow-x:hidden;margin-top:.5rem;box-sizing:border-box}.search-results-list{padding:.5rem}.search-result-item{border-bottom:1px solid var(--color-background-border);padding:.75rem 0}.search-result-item:last-child{border-bottom:none}.search-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.search-result-title{font-weight:600;color:var(--color-foreground-primary);font-size:.9rem}.search-result-section{font-size:.75rem;color:var(--color-foreground-secondary);background-color:var(--color-background-secondary);padding:.25rem .5rem;border-radius:.25rem}.search-result-matches{display:flex;flex-direction:column;gap:.25rem}.search-result-match{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s ease}.search-result-match:hover{background-color:var(--color-background-hover)}.match-type{font-size:.75rem;color:var(--color-brand-primary);font-weight:600;text-transform:uppercase;min-width:60px}.match-text{font-size:.85rem;color:var(--color-foreground-primary);line-height:1.4;flex:1}.match-text mark{background-color:var(--color-brand-primary);color:var(--color-background-primary);padding:.1rem .2rem;border-radius:.2rem}.link-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:1.5rem 0}@media(max-width:63em){.link-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}.link-grid-button{background-color:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;color:var(--color-foreground-primary);cursor:pointer;font-size:14px;font-weight:400;letter-spacing:.02em;padding:1.5rem;text-align:center;transition:all ease .3s;min-height:80px;display:flex;align-items:center;justify-content:center;box-shadow:none;position:relative;overflow:hidden}.link-grid-button:before{display:none}.link-grid-button:hover{background-color:var(--color-background-hover);border-color:var(--color-background-border);color:var(--color-foreground-primary)}.link-grid-button{flex-direction:column;gap:.5rem}.link-grid-description{font-size:.75rem;color:var(--color-foreground-secondary);font-weight:400;display:block;margin-top:.25rem}.link-grid-button.under-construction{position:relative;opacity:.8}.under-construction-badge{position:absolute;top:.5rem;right:.5rem;background-color:var(--color-background-border);color:var(--color-background-primary);font-size:.6rem;font-weight:700;padding:.2rem .5rem;border-radius:0;text-transform:uppercase;letter-spacing:.05em}.link-grid-button.under-construction:hover{opacity:1}.nav-overlay-icon{cursor:pointer;align-items:center;justify-content:center}.nav-overlay-icon .icon{color:var(--color-foreground-secondary);height:1.5rem;width:1.5rem;font-size:1.2rem}.theme-toggle-container,.help-toggle-container{display:flex;min-width:2.5rem;min-height:2.5rem;align-items:center;justify-content:center}.theme-toggle{background:transparent;border:none;cursor:pointer;display:flex;padding:0;align-items:center;justify-content:center;min-width:2.5rem;min-height:2.5rem}.theme-icon{font-size:1.25rem;color:var(--color-foreground-primary);display:flex;align-items:center;justify-content:center;width:1em;height:1em}.sidebar-drawer{position:fixed;top:var(--header-height);left:0;width:var(--sidebar-width, 15em);height:calc(100vh - var(--header-height));background-color:var(--color-sidebar-background);transition:none;z-index:999;overflow:hidden;box-shadow:none;backdrop-filter:none;border-right:1px solid var(--color-background-border);min-width:0;max-width:600px;transform:translate(-100%);pointer-events:none;visibility:hidden}#__navigation:checked~.page .sidebar-drawer{transform:translate(0);pointer-events:auto;visibility:visible}#__navigation:not(:checked)~.page .sidebar-drawer{transform:translate(-100%);pointer-events:none;visibility:hidden;border-right:none;box-shadow:none}#__navigation:not(:checked)~.page .sidebar-resize-handle{pointer-events:none;visibility:hidden}#__navigation:not(:checked)~.page .main{margin-left:0!important;max-width:100%!important}#__navigation:disabled~.page .sidebar-drawer{display:none!important;visibility:hidden!important;opacity:0!important}#__navigation:disabled~.page .nav-overlay-icon{display:none!important}.sidebar-resize-handle{position:absolute;top:0;right:-4px;width:8px;height:100%;cursor:col-resize;background:transparent;z-index:10;transition:background-color .2s ease}.sidebar-resize-handle:hover,.sidebar-resize-handle.resizing{background-color:var(--color-brand-primary);opacity:.3}.sidebar-resize-handle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:40px;background-color:var(--color-foreground-border);border-radius:1px;opacity:0;transition:opacity .2s ease}.sidebar-resize-handle:hover:before,.sidebar-resize-handle.resizing:before{opacity:1}[data-theme=dark] .sidebar-resize-handle:before{background-color:var(--color-foreground-border)}[data-theme=dark] .sidebar-resize-handle:hover,[data-theme=dark] .sidebar-resize-handle.resizing{background-color:var(--color-brand-primary);opacity:.4}.sidebar-drawer .sidebar-container{padding-top:0;width:100%;height:100%}.sidebar-container{box-sizing:border-box;width:15em;min-width:15em;height:100%}.sidebar-sticky{display:flex;flex-direction:column;height:100%;position:sticky;top:0}.sidebar-scroll{overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;padding-bottom:4rem;padding-top:1rem}.sidebar-tree{display:flex;flex-direction:column}.parent-folder{display:block}.children-nav{display:none;list-style:none;margin:0;padding:0}.children-nav.expanded{display:block}.sidebar-brand{display:flex;flex-direction:column;flex-shrink:0;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-decoration:none}.git-logo{width:24px;height:24px;margin-right:8px}[data-theme=light] #git-logo{filter:invert(100%)}[data-theme=dark] #git-logo{filter:invert(0%)}.sidebar-brand-text{color:var(--color-sidebar-brand-text);font-size:1.5rem;font-weight:700;overflow-wrap:break-word;margin:var(--sidebar-item-spacing-vertical) 0}.sidebar-tree{font-size:var(--sidebar-item-font-size);margin-bottom:var(--sidebar-item-spacing-vertical);margin-top:1.5rem;padding-bottom:2rem}.mobile-sidebar-nav{display:none}.sidebar-tree ul{display:flex;flex-direction:column;list-style:none;margin-bottom:0;margin-top:0;padding:0}.sidebar-tree li{margin:0;position:relative}.sidebar-tree .caption,.sidebar-tree :not(.caption)>.caption-text{color:var(--color-sidebar-caption-text);font-size:var(--sidebar-caption-font-size);font-weight:700;margin:1rem 0 0;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-transform:uppercase}.sidebar-tree .reference{color:var(--color-sidebar-link-text);box-sizing:border-box;display:inline-block;height:100%;line-height:var(--sidebar-item-line-height);overflow-wrap:anywhere;padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);text-decoration:none;width:100%;border-radius:0;margin:.125rem .5rem;transition:all ease .3s;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-tree .reference:hover{background:var(--color-sidebar-item-background--hover);color:var(--color-sidebar-link-text)}.children-nav{display:none;list-style:none;margin:0;padding:0;overflow:hidden;transition:all .3s ease}.children-nav.expanded{display:block;animation:expandDown .3s ease-out}.children-nav.collapsed{display:none!important;animation:collapseUp .3s ease-in}.child-reference{padding-left:2rem!important;font-size:.9em;color:var(--color-sidebar-link-text);transition:all ease .3s;border-radius:0}.parent-reference{font-weight:700;color:var(--color-sidebar-link-text--top-level);padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);transition:all ease .3s;border-radius:0}.expand-icon{display:inline-block;margin-right:.5rem;transition:transform .2s ease;font-size:.75em;width:1.2em;text-align:center;font-family:Arial,sans-serif;line-height:1;font-weight:700}.sidebar-tree .toctree-l1>.reference{color:var(--color-sidebar-link-text--top-level);font-weight:600}.sidebar-tree .current-page>.reference{font-weight:700;background:var(--color-brand-primary);color:var(--color-background-primary);box-shadow:var(--shadow-sm)}.main{flex:1;width:100%;margin-left:0;transition:margin-left .3s ease,max-width .3s ease;padding-top:calc(var(--header-height));overflow-x:hidden;overflow-y:visible;max-width:100%}.content{display:flex;flex-direction:column;justify-content:space-between;width:100%;max-width:90%;margin:0 auto;overflow-x:clip}.article-container{color:var(--color-foreground-primary);overflow-wrap:break-word;overflow-x:clip;max-width:100%}section{background:var(--color-background-primary)}.tab-content{display:none}.tab-content.active{display:block}article{line-height:1.5}h1,h2,h3,h4,h5,h6{border-radius:.5rem;font-family:var(--font-stack--headings);font-weight:700;line-height:1.25;letter-spacing:.05em;text-transform:uppercase;margin:.5rem -.5rem;padding-left:.5rem;padding-right:.5rem}h1{font-size:2.5em;margin-bottom:1rem;margin-top:1.75rem}h2{font-size:2em;margin-top:1.75rem}h3{font-size:1.5em}h4{font-size:1.25em}h5{font-size:1.125em}h6{font-size:1em}h1+p,h2+p,h3+p,h4+p,h5+p,h6+p{margin-top:0}p{margin-bottom:.75rem;margin-top:.5rem;color:var(--color-foreground-primary)}.content-section{color:var(--color-foreground-primary)}article,main,aside{background-color:inherit}.content-section h3,.content-section h4,.content-section p,.content-section li{color:var(--color-foreground-primary)}.content-section strong{color:var(--color-foreground-primary);font-weight:600}a{color:var(--color-link);text-decoration:underline;transition:all ease .3s}a:hover{color:var(--color-link);text-decoration:underline}.headerlink{font-weight:100;user-select:none;margin-left:.5rem;visibility:hidden;text-decoration:none}h1:hover>.headerlink,h2:hover>.headerlink,h3:hover>.headerlink,h4:hover>.headerlink,h5:hover>.headerlink,h6:hover>.headerlink{visibility:visible}code,kbd,pre,samp{font-family:var(--font-stack--monospace)}code{background:var(--color-inline-code-background);border-radius:0;font-size:var(--font-size--small);padding:.1em .2em}pre code,pre.astro-code code,.astro-code code{background:transparent;font-size:inherit;padding:0}.code-block{background:var(--color-code-background);border:1px solid var(--color-background-border);border-radius:0;margin:1.5rem 0;overflow:hidden;box-shadow:none;position:relative;max-height:calc(100vh - var(--header-height) - 2rem);display:flex;flex-direction:column}.code-block:before{display:none}.code-block pre:not(.astro-code){color:var(--color-code-foreground);font-family:var(--font-stack--monospace);font-size:var(--code-font-size);line-height:1.6;margin:0;padding:1.5rem;overflow-x:auto;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word;max-width:100%;flex:1;min-height:0}.code-block pre:not(.astro-code) code{color:var(--color-code-foreground);background:transparent;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.code-copy-button{user-select:none}.code-copy-button:hover{background-color:var(--color-background-hover)!important}.code-copy-button.copied{color:var(--color-success)!important}.code-copy-button.copied .copy-icon{color:var(--color-success)}.code-copy-button:active{transform:scale(.95)}.code-block code .java-keyword{color:#000;font-weight:700}.code-block code .java-type{color:#007a3d;font-weight:600}.code-block code .java-literal{color:#ce1126;font-weight:500}.code-block code .java-string{color:#007a3d}.code-block code .java-number{color:#ce1126}.code-block code .java-comment{color:#666;font-style:italic}.code-block code .java-annotation{color:#ce1126;font-weight:600}html[data-theme=dark] .code-block code .java-keyword{color:#fff;font-weight:700}html[data-theme=dark] .code-block code .java-type{color:#007a3d;font-weight:600}html[data-theme=dark] .code-block code .java-literal{color:#ce1126;font-weight:500}html[data-theme=dark] .code-block code .java-string{color:#007a3d}html[data-theme=dark] .code-block code .java-number{color:#ce1126}html[data-theme=dark] .code-block code .java-comment{color:#999;font-style:italic}html[data-theme=dark] .code-block code .java-annotation{color:#ce1126;font-weight:600}.code-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--color-background-secondary);border-bottom:1px solid var(--color-background-border);border-radius:0;font-size:.9em;color:var(--color-foreground-secondary);font-weight:500;flex-shrink:0}.code-toggle-btn{background:none;border:none;color:var(--color-foreground-secondary);cursor:pointer;font-size:1.2em;font-weight:700;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background-color .2s}.code-toggle-btn:hover{background-color:var(--color-background-hover)}.code-toggle-btn:active{background-color:var(--color-background-border)}[data-theme=dark] .code-header{background:var(--color-background-secondary);border-bottom-color:var(--color-background-border);color:var(--color-foreground-secondary)}[data-theme=dark] .code-toggle-btn{color:var(--color-foreground-secondary)}[data-theme=dark] .code-toggle-btn:hover{background-color:var(--color-background-hover)}@media(max-width:48em){.code-header{padding:6px 10px;font-size:.85em}.code-toggle-btn{width:18px;height:18px;font-size:1.1em}}.code-tabs-container{background:var(--color-code-background);border:1px solid var(--color-background-border);border-radius:0;margin:1.5rem 0;overflow:hidden;box-shadow:none;position:relative;max-height:calc(100vh - var(--header-height) - 2rem);display:flex;flex-direction:column}.code-tabs-container:before{display:none}[data-code-tabs-mode=slots] .code-tabs-content>.code-tab-content:not(:first-child){display:none}[data-code-tabs-mode=slots] .code-tabs-content>.code-tab-content:first-child{display:flex}.code-tabs-header{display:flex;background:var(--color-background-primary);border-bottom:1px solid var(--color-background-border);overflow-x:auto;padding-top:0;flex-shrink:0;align-items:center}.code-tabs-wrapper{display:flex;flex:1;overflow-x:auto;min-width:0}.code-tabs-header .copy-button.code-tabs-copy{background:transparent;border:none;border-radius:0;box-shadow:none;color:var(--color-foreground-secondary);cursor:pointer;font-family:var(--font-stack--monospace);font-size:14px;font-weight:400;padding:10px 16px;white-space:nowrap;transition:all ease .3s;flex-shrink:0;margin-left:auto;user-select:none;outline:none}.code-tabs-header .copy-button.code-tabs-copy:hover{background:var(--color-background-hover);color:var(--color-foreground-primary)}.code-tabs-header .copy-button.code-tabs-copy:focus-visible{outline:2px solid var(--color-foreground-primary);outline-offset:-2px}.code-tabs-header .copy-button.code-tabs-copy.copied{color:var(--color-success)}.code-tabs-header .copy-button.code-tabs-copy:active{transform:none}.code-tab-button{padding:10px 16px;background:transparent;border:none;border-bottom:1px solid transparent;color:var(--color-foreground-secondary);cursor:pointer;font-size:14px;font-weight:400;white-space:nowrap;transition:all ease .3s;font-family:var(--font-stack--monospace);position:relative}.code-tab-button:hover{background:var(--color-background-hover)}.code-tab-button[data-active=true],.code-tab-button.active{background:var(--color-background-primary);border-bottom-color:var(--color-foreground-primary);color:var(--color-foreground-primary);font-weight:400}.code-tabs-content{position:relative;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.code-tab-content{display:none}.code-tab-content.active{display:block}.code-tab-content{height:100%;display:flex;flex-direction:column}.code-tab-content .code-block{border:none;border-radius:0;margin:0;box-shadow:none;max-height:100%;height:100%;display:flex;flex-direction:column}.code-tab-content .code-block pre{flex:1;min-height:0}.code-tabs-container pre.astro-code{border:none;margin:0;max-height:none}.code-tab-content .code-block:before{display:none}html[data-theme=dark] .code-tabs-container{background:var(--color-code-background);border-color:var(--color-background-border)}html[data-theme=dark] .code-tabs-header{background:var(--color-background-secondary);border-bottom-color:var(--color-background-border)}html[data-theme=dark] .code-tab-button{color:var(--color-foreground-secondary)}html[data-theme=dark] .code-tab-button:hover{background:var(--color-background-hover)}html[data-theme=dark] .code-tab-button[data-active=true],html[data-theme=dark] .code-tab-button.active{background:var(--color-background);border-bottom-color:var(--color-brand-primary);color:var(--color-brand-primary)}html[data-theme=dark] .code-tabs-header .copy-button.code-tabs-copy{color:var(--color-foreground-secondary)}html[data-theme=dark] .code-tabs-header .copy-button.code-tabs-copy:hover{background:var(--color-background-hover);color:var(--color-brand-primary)}html[data-theme=dark] .code-tabs-header .copy-button.code-tabs-copy.copied{color:var(--color-brand-primary)}@media(max-width:48em){.code-tab-button,.code-tabs-header .copy-button.code-tabs-copy{padding:8px 12px;font-size:.85em}}ol,ul{margin-bottom:1rem;margin-top:1rem;padding-left:1.2rem}ol li>p:first-child,ul li>p:first-child{margin-bottom:.25rem;margin-top:.25rem}ol li>p:last-child,ul li>p:last-child{margin-top:.25rem}.youtube-embed{position:relative;width:100%;max-width:56rem;margin:1.5rem 0 2rem;aspect-ratio:16 / 9;border:1px solid var(--color-background-border);background:var(--color-background-secondary)}.youtube-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.rules-box{background:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;padding:1.5rem;margin:2rem 0;box-shadow:none;position:relative;overflow:hidden}.rules-box:before{display:none}.rules-box h3{color:var(--color-brand-primary);font-size:1.25rem;font-weight:700;margin:0 0 .5rem;padding-left:1rem}.rules-box h4{color:var(--color-foreground-secondary);font-size:1rem;font-weight:500;margin:.5rem 0 1rem;padding-left:1rem}.rules-box ul{margin:0;padding-left:1.5rem}.rules-box li{margin-bottom:.75rem;line-height:1.6;color:var(--color-foreground-primary);padding-left:.5rem}.rules-box li:last-child{margin-bottom:0}.rules-box strong{color:var(--color-brand-primary);font-weight:600}.exercise-box{background:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;padding:2rem;margin:2rem 0;box-shadow:none;position:relative;overflow:hidden}.exercise-box:before{display:none}.hint-box{background-color:#faf2e6;border:1px solid var(--color-background-border);color:#333;padding:1em;margin-top:1em;border-radius:0}.hint-box h5,.hint-box p{margin-top:0;color:#333}.exercise-code{margin-top:.5rem;border:1px solid var(--color-background-border);border-radius:0;background:var(--color-code-background)}.exercise-code pre{margin:0;padding:1rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-width:100%}.exercise-code code{font-size:.85rem;line-height:1.5;color:var(--color-code-foreground);white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.data-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:2rem 0}.data-type-card{background:var(--color-background-primary);color:var(--color-foreground-primary);padding:2rem;border-radius:0;text-align:center;transition:all ease .3s;border:1px solid var(--color-background-border);box-shadow:none;position:relative;overflow:hidden}.data-type-card:before{display:none}.data-type-card:hover{background-color:var(--color-background-hover);border-color:var(--color-background-border)}.data-type-card h4{color:var(--color-brand-primary);font-size:1.5rem;margin-bottom:.5rem;font-weight:700}.data-type-card code{background:var(--color-code-background);color:var(--color-code-foreground);display:block;margin:1rem 0;padding:1rem;border-radius:0;font-family:var(--font-stack--monospace);border:1px solid var(--color-background-border)}footer{display:flex;flex-direction:column;font-size:var(--font-size--small);margin-top:2rem}.bottom-of-page{align-items:center;border-top:1px solid var(--color-background-border);color:var(--color-foreground-secondary);display:flex;justify-content:space-between;line-height:1.5;margin-top:1rem;padding-bottom:1rem;padding-top:1rem}.bottom-of-page .left-details{font-size:var(--font-size--small)}.sidebar-toggle{display:none;position:absolute}.overlay{position:fixed;top:0;left:0;width:0;height:0;background-color:#00000080;opacity:0;transition:none;z-index:29;pointer-events:none}@media(max-width:63em){#__navigation:checked~.sidebar-overlay.overlay{width:100vw;height:100vh;opacity:1;transition:none;pointer-events:auto;z-index:29}.sidebar-drawer{left:0;position:fixed;top:var(--header-height);width:var(--sidebar-width, 15em);height:calc(100vh - var(--header-height));z-index:999;transition:none}#__navigation:checked~.page .sidebar-drawer{transform:translate(0);pointer-events:auto;visibility:visible;box-shadow:2px 0 16px #00000040;z-index:999}#__navigation:checked~.page .main{margin-left:0!important;max-width:100%!important;transition:none!important}}#__navigation:checked~.page .sidebar-drawer{left:0;top:var(--header-height);transform:translate(0);pointer-events:auto;visibility:visible}#__navigation:checked~.page .main{max-width:calc(100% - var(--sidebar-width, 15em));margin-left:var(--sidebar-width, 15em);transition:none}#__navigation:disabled~.page .main{max-width:100%!important;margin-left:0!important;transition:none!important}.main{transition:none}@media(max-width:82em){.sidebar-drawer{width:var(--sidebar-width, 15em)}}@media(max-width:67em){.content{margin-left:auto;margin-right:auto;padding:0 1em;max-width:95%}}@media(max-width:63em){.nav-overlay-icon{display:flex}.sidebar-drawer{height:calc(100vh - var(--header-height));left:0;position:fixed;top:var(--header-height);width:var(--sidebar-width, 15em)}.theme-toggle-header{display:flex}.header-navigation{display:none}.search-container-header{display:flex;justify-content:center;align-items:center;width:100%;margin:0 auto;flex:1 1 100%;order:2}.search-input-header{width:50vw;min-width:120px;max-width:400px;margin:0 auto;font-size:1rem;padding:.75rem 1rem;box-sizing:border-box}.mobile-header .header-center{display:none}.mobile-header .header-right{flex:1 1 100%;display:flex;justify-content:center;align-items:center;width:100%;margin:0;padding:0}.mobile-sidebar-nav{display:block;padding:1rem var(--sidebar-item-spacing-horizontal);border-bottom:1px solid var(--color-background-border);background:var(--color-sidebar-background);margin-bottom:1rem}.mobile-sidebar-search-container{margin-bottom:1rem;position:relative;z-index:1001}.mobile-sidebar-search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--color-background-border);border-radius:0;background:var(--color-background-primary);color:var(--color-foreground-primary);font-size:.95rem;font-family:var(--font-stack);transition:all .2s ease;outline:none}.mobile-sidebar-search-input:focus{border-color:var(--color-brand-primary);box-shadow:0 0 0 3px rgba(var(--color-brand-primary-rgb),.1);background:var(--color-background-primary)}.mobile-sidebar-search-input::placeholder{color:var(--color-foreground-muted);opacity:.8}.mobile-sidebar-search-container .search-results{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:.5rem;max-height:60vh;overflow-y:auto;background:var(--color-sidebar-background);border:1px solid var(--color-background-border);border-radius:0;box-shadow:none;max-width:100%;box-sizing:border-box}.mobile-sidebar-search-container .search-results-list{max-height:50vh;overflow-y:auto}.mobile-sidebar-search-container .search-result-item{padding:.75rem;border-bottom:1px solid var(--color-background-border)}.mobile-sidebar-search-container .search-result-item:last-child{border-bottom:none}.sidebar-scroll{max-height:calc(100vh - 200px)}.mobile-sidebar-nav .header-nav-link{display:flex;align-items:center;margin-bottom:.75rem;padding:.75rem 1rem;border-radius:.5rem;color:var(--color-sidebar-link-text);text-decoration:none;font-weight:500;font-size:.95rem;transition:all .2s ease;border:1px solid transparent;position:relative;overflow:hidden}.mobile-sidebar-nav .header-nav-link:before{display:none}.mobile-sidebar-nav .header-nav-link:hover{background-color:var(--color-sidebar-item-background--hover);border-color:var(--color-background-border)}.mobile-sidebar-nav .header-nav-link:hover:before{display:none}.mobile-sidebar-nav .header-nav-link.active{background:var(--color-background-hover);color:var(--color-sidebar-link-text--top-level);border-color:var(--color-background-border)}.mobile-sidebar-nav .header-nav-link.active:before{display:none}.mobile-sidebar-nav .header-nav-link:last-child{margin-bottom:0}.mobile-sidebar-nav{padding-bottom:1rem}.page{justify-content:center}.mobile-header{display:flex}.main{margin-top:var(--header-height)}}@media(max-width:48em){.content{overflow-x:auto;width:100%;max-width:98%;padding:0 .5em}.code-block pre{padding:1rem .75rem;font-size:.9rem}.exercise-code pre{padding:.75rem;font-size:.9rem}}@media(max-width:46em){.bottom-of-page{flex-direction:column-reverse;gap:.25rem;text-align:center}.data-types-grid,.link-grid{grid-template-columns:1fr}.link-grid-button{padding:1rem;font-size:1rem;min-height:60px}.mobile-header{min-height:var(--header-height);padding:0 .5rem}.mobile-header .header-left,.mobile-header .header-right{padding:0 .5rem}.nav-overlay-icon .icon{font-size:1.2em}.theme-toggle{padding:.5rem}}@media(max-width:32em){.mobile-header,.mobile-header .header-left,.mobile-header .header-right{padding:0 .25rem}.nav-overlay-icon{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.theme-toggle{min-width:44px;min-height:44px}.mobile-sidebar-search-input{padding:.875rem 1rem;font-size:1rem}.mobile-sidebar-search-container .search-results{max-height:50vh}}.parent-tab{position:relative}.parent-reference{display:flex;align-items:center;font-weight:600;color:var(--color-sidebar-brand-text);text-decoration:none;padding:.5rem var(--sidebar-item-spacing-horizontal);border-radius:.25rem;transition:all .15s ease}.parent-reference:hover{background-color:var(--color-sidebar-item-background--hover);color:var(--color-sidebar-link-text--top-level)}.expand-icon{margin-right:.5rem;font-size:.75rem;transition:transform .2s ease;user-select:none;font-family:Arial,sans-serif;line-height:1;width:1.2em;text-align:center;font-weight:700}.children-nav{margin-left:1rem;margin-top:.25rem;margin-bottom:.25rem;overflow:hidden;transition:all .3s ease}.children-nav.expanded{max-height:none;opacity:1}.children-nav.collapsed{display:none!important;max-height:0;opacity:0;margin:0}.child-tab{margin:0;padding:0}.child-reference{display:block;color:var(--color-sidebar-link-text);text-decoration:none;padding:.375rem var(--sidebar-item-spacing-horizontal);border-radius:0;font-size:.9rem;transition:all ease .3s;border-left:none}.child-reference:hover{background-color:var(--color-sidebar-item-background--hover);color:var(--color-sidebar-link-text--top-level)}.parent-tab.current-page>.parent-reference{background-color:var(--color-background-hover);color:var(--color-sidebar-link-text--top-level);font-weight:700}.child-tab.current-page>.child-reference{background-color:var(--color-background-hover);color:var(--color-sidebar-link-text--top-level);font-weight:700}.sidebar-scroll{scroll-behavior:auto}@media(max-width:67em){.children-nav{margin-left:.5rem}.child-reference{padding:.25rem var(--sidebar-item-spacing-horizontal);font-size:.95rem}.parent-reference{padding:.375rem var(--sidebar-item-spacing-horizontal)}}@media(min-width:64em){.mobile-sidebar-nav{display:none}}.parent-reference:focus,.child-reference:focus{outline:2px solid var(--color-brand-primary);outline-offset:2px}.parent-reference{border-bottom:none;margin-bottom:.25rem}.parent-tab:last-child .parent-reference{border-bottom:none}.children-nav{transform-origin:top}.children-nav.expanded{animation:expandDown .3s ease-out}.children-nav.collapsed{animation:collapseUp .3s ease-in}@keyframes expandDown{0%{max-height:0;opacity:0;transform:scaleY(0)}to{max-height:none;opacity:1;transform:scaleY(1)}}@keyframes collapseUp{0%{max-height:none;opacity:1;transform:scaleY(1)}to{max-height:0;opacity:0;transform:scaleY(0)}}[data-theme=dark] .parent-reference{color:var(--color-sidebar-brand-text)}[data-theme=dark] .child-reference{color:var(--color-sidebar-link-text)}[data-theme=dark] .parent-reference:hover,[data-theme=dark] .child-reference:hover{color:var(--color-sidebar-link-text--top-level)}.answer-toggle-btn{background:var(--color-accent);color:var(--color-background-primary);border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;margin-top:1rem;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.answer-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;background:var(--color-accent)}.answer-toggle-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.answer-toggle-btn.active,.answer-toggle-btn.active:hover{background:var(--color-accent)}.answer-section{margin-top:1rem;border:1px solid var(--color-background-border);border-radius:0;padding:1.5rem;background:var(--color-background-secondary);transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden;margin-bottom:2rem;word-wrap:break-word;overflow-wrap:break-word;transform-origin:top}.answer-section.hidden{max-height:0;padding:0 1.5rem;border-width:0;opacity:0;transform:scaleY(0);pointer-events:none}.answer-section.visible{max-height:none;opacity:1;transform:scaleY(1);pointer-events:auto}.answer-title{margin:0 0 1rem;color:var(--color-brand-primary);font-size:1.1rem;font-weight:600;border-bottom:1px solid var(--color-background-border);padding-bottom:.5rem}.answer-item{margin-bottom:1.5rem}.answer-item:last-child{margin-bottom:0}.answer-task-label{margin:0 0 .5rem;color:var(--color-foreground-primary);font-size:1rem;font-weight:600}.answer-code{margin-top:.5rem;border:1px solid var(--color-background-border);border-radius:0;background:var(--color-background-primary)}.answer-code pre{margin:0;padding:1rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-width:100%}.answer-code code{font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.answer-section .code-block{max-width:100%;overflow-x:auto;word-wrap:break-word;overflow-wrap:break-word}.answer-section .code-block pre,.answer-section .code-block code{white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}[data-theme=dark] .answer-section{background:var(--color-background-primary);border-color:var(--color-background-border)}[data-theme=dark] .answer-code{background:var(--color-background-secondary)}[data-theme=dark] .answer-toggle-btn{box-shadow:0 2px 4px #ffffff1a}[data-theme=dark] .answer-toggle-btn:hover{box-shadow:0 4px 8px #ffffff26}@media(max-width:67em){.answer-toggle-btn{width:100%;padding:.75rem;font-size:.95rem}.answer-section{padding:1rem}.answer-section.hidden{padding:0 1rem}.answer-task-label,.answer-code code{font-size:.9rem}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media(max-width:63em){.search-results{left:0;right:0;transform:none;width:90%;min-width:0;max-width:min(400px,calc(100vw - 2rem));margin:0 auto;border-radius:0;box-sizing:border-box;overflow-x:hidden}}.keyboard-shortcuts-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;backdrop-filter:blur(4px);z-index:9999;display:none;align-items:center;justify-content:center;pointer-events:none;visibility:hidden}.keyboard-shortcuts-overlay[hidden]{display:none!important;pointer-events:none!important;visibility:hidden!important}.keyboard-shortcuts-overlay:not(.visible) *,.keyboard-shortcuts-overlay[hidden] *{pointer-events:none!important}.keyboard-shortcuts-overlay.visible{display:flex;pointer-events:auto;visibility:visible}.keyboard-shortcuts-overlay.visible *{pointer-events:auto}.keyboard-shortcuts-modal{background-color:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;box-shadow:none;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;transform:scale(.95);transition:transform .3s ease}.keyboard-shortcuts-overlay.visible .keyboard-shortcuts-modal{transform:scale(1)}.keyboard-shortcuts-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--color-background-border)}.keyboard-shortcuts-header h2{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-foreground-primary);text-transform:uppercase;letter-spacing:.05em}.keyboard-shortcuts-close{background:none;border:none;font-size:1.5rem;color:var(--color-foreground-muted);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:color .2s ease,background-color .2s ease;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.keyboard-shortcuts-close:hover{color:var(--color-foreground-primary);background-color:var(--color-background-hover)}.keyboard-shortcuts-close:focus{outline:2px solid var(--color-brand-primary);outline-offset:2px}.keyboard-shortcuts-close:focus:not(:focus-visible){outline:none}.keyboard-shortcuts-content{padding:1.5rem}.shortcut-group{margin-bottom:2rem;background:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;overflow:hidden;box-shadow:none}.shortcut-group:last-child{margin-bottom:0}.shortcut-group h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:var(--color-foreground-primary);background:var(--color-background-secondary);border-bottom:1px solid var(--color-background-border);border-radius:0;padding:8px 12px;font-size:.9em;color:var(--color-foreground-secondary);font-weight:500}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--color-background-border);background:var(--color-background-primary)}.shortcut-item:last-child{border-bottom:none}.shortcut-item:hover{background:var(--color-background-hover)}.shortcut-key{background-color:var(--color-code-background);color:var(--color-code-foreground);padding:.25rem .5rem;border-radius:0;font-family:var(--font-stack--monospace);font-size:.875rem;font-weight:500;border:1px solid var(--color-background-border);min-width:120px;text-align:center;user-select:none;box-shadow:none;transition:all .2s ease}.shortcut-key:hover{background:var(--color-background-hover)}.shortcut-description{color:var(--color-foreground-secondary);font-size:.9rem;flex:1;margin-left:1rem}[data-theme=dark] .keyboard-shortcuts-modal{background-color:var(--color-background-secondary);border-color:var(--color-background-border)}[data-theme=dark] .keyboard-shortcuts-header{border-bottom-color:var(--color-background-border)}[data-theme=dark] .shortcut-group h3{background:var(--color-background-secondary);border-bottom-color:var(--color-background-border);color:var(--color-foreground-secondary)}[data-theme=dark] .shortcut-group{background:var(--color-background-secondary);border-color:var(--color-background-border)}[data-theme=dark] .shortcut-item{border-bottom-color:var(--color-background-border);background:var(--color-background-secondary)}[data-theme=dark] .shortcut-item:hover{background:var(--color-background-hover)}[data-theme=dark] .shortcut-key{background-color:var(--color-code-background);color:var(--color-code-foreground);border-top-color:var(--color-brand-primary)}@media(max-width:48em){.help-toggle{width:1.75rem;height:1.75rem;font-size:.9rem}.help-icon{font-size:.9rem}.keyboard-shortcuts-modal{width:95%;max-height:90vh}.keyboard-shortcuts-header{padding:1rem 1rem .75rem}.keyboard-shortcuts-header h2{font-size:1.25rem}.keyboard-shortcuts-content{padding:1rem}.shortcut-item{flex-direction:column;align-items:flex-start;gap:.5rem}.shortcut-key{min-width:auto;align-self:flex-start}.shortcut-description{margin-left:0}}@media(max-width:32em){.keyboard-shortcuts-modal{width:98%;max-height:95vh}.keyboard-shortcuts-header{padding:.75rem .75rem .5rem}.keyboard-shortcuts-content{padding:.75rem}.shortcut-group{margin-bottom:1.5rem}.shortcut-group h3{font-size:1rem;margin-bottom:.75rem}.shortcut-item{padding:.5rem 0}}.help-toggle-container{display:flex;align-items:center}.help-toggle{background:none;color:var(--color-foreground-secondary);border:none;border-radius:var(--radius-sm);box-shadow:none;padding:.5rem;display:flex;align-items:center;font-size:.9rem;font-weight:500;cursor:pointer;margin-right:.75rem;outline:none;transition:color .18s,background .18s}.help-toggle:hover,.help-toggle:focus{background:var(--color-background-hover);color:var(--color-foreground-primary)}.help-icon{font-size:1rem;margin-right:0;display:flex;align-items:center;justify-content:center}.shortcut-key{background:var(--color-background-primary);color:var(--color-code-foreground);padding:.25rem .5rem;border-radius:var(--radius-sm);font-family:var(--font-stack--monospace);font-size:.875rem;font-weight:500;border:none;min-width:120px;text-align:center;user-select:none;box-shadow:var(--shadow-sm);transition:all .2s ease}[data-theme=dark] .shortcut-key{background:var(--color-background-primary);color:var(--color-code-foreground)}:root .shortcut-key{background:var(--color-background-secondary);color:var(--color-code-foreground)}.notification-popup{position:fixed;top:calc(var(--header-height) + 10px);right:20px;background:var(--color-background-secondary);color:var(--color-foreground-secondary);padding:6px 10px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);border:1px solid var(--color-background-border);border-radius:0;font-family:var(--font-stack--monospace);font-size:.75rem;font-weight:400;z-index:10000;opacity:0;transform:translateY(10px);transition:all .2s ease;max-width:200px;word-wrap:break-word;cursor:pointer;user-select:none}.notification-popup:hover{background:var(--color-background-hover);color:var(--color-foreground-primary);border-color:var(--color-brand-primary)}[data-theme=dark] .notification-popup{background:var(--color-background-secondary);color:var(--color-foreground-secondary);border-color:var(--color-background-border)}[data-theme=dark] .notification-popup:hover{background:var(--color-background-hover);color:var(--color-foreground-primary);border-color:var(--color-brand-primary)}@media(max-width:48em){.notification-popup{top:calc(var(--header-height) + 5px);right:10px;left:10px;max-width:none;transform:translateY(5px)}.notification-popup:hover{transform:translateY(0)}}.page-navigation{display:flex!important;justify-content:space-between;align-items:stretch;margin-top:3rem;margin-bottom:2rem;padding-top:2rem;border-top:1px solid var(--color-background-border);gap:1rem;width:100%;min-height:50px}.nav-button{display:flex;align-items:center;gap:.875rem;padding:1rem 1.25rem;background-color:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;color:var(--color-foreground-primary);font-family:var(--font-stack);font-size:14px;font-weight:400;letter-spacing:.02em;cursor:pointer;transition:all ease .3s;text-decoration:none;max-width:48%;min-width:0;flex:1;box-shadow:none;position:relative;overflow:hidden;text-align:left}.nav-button:before{display:none}.nav-button:hover{background-color:var(--color-background-hover);border-color:var(--color-background-border);color:var(--color-foreground-primary)}.nav-button-prev{justify-content:flex-start;text-align:left}.nav-button-next{justify-content:flex-end;margin-left:auto;text-align:right}.nav-button-content{display:flex;flex-direction:column;align-items:flex-start;min-width:0;flex:1;gap:.25rem;text-align:left}.nav-button-next .nav-button-content{align-items:flex-end;text-align:right}.nav-button-label{font-family:var(--font-stack);font-size:var(--font-size--small--2);color:var(--color-foreground-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;line-height:1.2;text-align:inherit;display:block}.nav-button-prev .nav-button-label{text-align:left}.nav-button-next .nav-button-label{text-align:right}.nav-button-title{font-family:var(--font-stack);font-size:.95rem;color:var(--color-foreground-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;line-height:1.4;text-align:inherit;display:block}.nav-button-prev .nav-button-title{text-align:left}.nav-button-next .nav-button-title{text-align:right}.nav-button:hover .nav-button-title{color:var(--color-brand-primary)}.nav-button-icon{font-size:1.5rem;color:var(--color-brand-primary);font-weight:400;flex-shrink:0;transition:transform .3s ease;line-height:1;display:flex;align-items:center}.nav-button-prev:hover .nav-button-icon{transform:translate(-4px)}.nav-button-next:hover .nav-button-icon{transform:translate(4px)}@media(max-width:768px){.page-navigation{flex-direction:column;gap:.75rem}.nav-button{max-width:100%;width:100%}.nav-button-next{margin-left:0}.nav-button-next .nav-button-content{align-items:flex-start;text-align:left}}html{scrollbar-gutter:stable}.mobile-header{height:var(--header-height);min-height:var(--header-height);max-height:var(--header-height);contain:strict;content-visibility:visible}.sidebar-drawer{contain:layout style}.main{min-height:calc(100vh - var(--header-height) - 100px)}#tab-container{min-height:280px;contain:layout;overflow-anchor:auto}.sidebar-scroll{overflow-anchor:auto;overscroll-behavior:contain}.search-results{contain:strict;content-visibility:auto}img{max-width:100%;height:auto;vertical-align:middle}.theme-icon,.help-icon,.copy-icon{display:inline-flex;width:1em;height:1em;align-items:center;justify-content:center}#loading-overlay,.loading-overlay{contain:strict;position:fixed;top:0;left:0;width:100%;height:100%;min-width:100vw;min-height:100vh;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--color-background-primary, #fff);color:var(--color-foreground-primary, #333);font-size:1.5rem;font-family:var(--font-stack);will-change:opacity}.fa-solid,.fa-regular,.fa-brands,.fab,.fas,.far{display:inline-block;width:1em;height:1em;vertical-align:-.125em}.keyboard-shortcuts-modal{contain:content}.breadcrumb-nav{margin-bottom:1.5rem;padding:.75rem 0;font-size:var(--font-size--small)}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;list-style:none;margin:0;padding:0;gap:.5rem}.breadcrumb-item{display:flex;align-items:center}.breadcrumb-item:not(:last-child):after{content:">";margin-left:.5rem;color:var(--color-foreground-muted);font-weight:400}.breadcrumb-item a{color:var(--color-foreground-secondary);text-decoration:none;transition:color .2s ease;padding:.25rem 0}.breadcrumb-item a:hover{color:var(--color-brand-primary);text-decoration:underline}.breadcrumb-item.breadcrumb-current span{color:var(--color-foreground-primary);font-weight:500}[data-theme=dark] .breadcrumb-item a{color:var(--color-foreground-secondary)}[data-theme=dark] .breadcrumb-item a:hover{color:var(--color-brand-primary)}[data-theme=dark] .breadcrumb-item.breadcrumb-current span{color:var(--color-foreground-primary)}@media(max-width:48em){.breadcrumb-nav{padding:.5rem 0;margin-bottom:1rem}.breadcrumb-list{font-size:var(--font-size--small--2)}.breadcrumb-item:not(:last-child):after{margin-left:.25rem}}.seo-content{max-width:800px;margin:2rem auto;padding:2rem;font-family:var(--font-stack);line-height:1.6;color:var(--color-foreground-primary)}.seo-content h1{font-size:2rem;margin-bottom:1rem;color:var(--color-brand-primary)}.seo-content h2{font-size:1.5rem;margin-top:2rem;margin-bottom:1rem;color:var(--color-foreground-primary)}.seo-content p{margin-bottom:1rem}.seo-content ul{padding-left:1.5rem;margin-bottom:1rem}.seo-content li{margin-bottom:.5rem}.seo-content strong{color:var(--color-brand-primary)}noscript .seo-content{display:block}@media print{.mobile-header,.sidebar-drawer,.sidebar-overlay,.page-navigation,.search-container-header,.theme-toggle-container,.help-toggle-container{display:none!important}.main{margin-left:0!important;max-width:100%!important}.content{max-width:100%!important;padding:0!important}.code-block{break-inside:avoid;page-break-inside:avoid}}.sidebar-group{margin-bottom:.5rem}.sidebar-group-label{display:block;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-foreground-secondary);padding:.5rem .75rem .25rem}.sidebar-link{display:block;padding:.35rem .75rem;color:var(--color-foreground-primary);text-decoration:none;font-size:12px;line-height:1.5;transition:all ease .3s}.sidebar-link:hover,.sidebar-link.active{background:var(--color-background-secondary);color:var(--color-brand-primary)}.sidebar-meta{display:block;font-size:10px;color:var(--color-foreground-secondary)}.lesson-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-background-border)}.lesson-header h1{margin-bottom:.5rem}.lesson-meta{display:flex;gap:1rem;font-size:12px;color:var(--color-foreground-secondary)}.lesson-difficulty{text-transform:capitalize}.lesson-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-background-border)}.lesson-nav-link{display:flex;flex-direction:column;text-decoration:none;color:var(--color-foreground-primary);padding:.75rem 1rem;border:1px solid var(--color-background-border);border-radius:0;max-width:45%;transition:all ease .3s}.lesson-nav-link:hover{background:var(--color-background-secondary);color:var(--color-brand-primary)}.lesson-nav-next{margin-left:auto;text-align:right}.lesson-nav-label{font-size:10px;text-transform:uppercase;color:var(--color-foreground-secondary)}.lesson-nav-title{font-weight:600;font-size:13px}a.link-grid-button{text-decoration:none;color:inherit}.rules-box-subtitle{margin-top:.5rem;margin-bottom:1rem;color:var(--color-foreground-secondary);font-weight:500}.rules-box-good{color:var(--color-success);font-weight:600}.rules-box-avoid{color:var(--color-error);font-weight:600}.search-results-overlay{display:none;position:fixed;inset:0;z-index:10000;background:#0009;align-items:flex-start;justify-content:center;padding-top:calc(var(--header-height) + 1rem);padding-bottom:2rem;overflow-y:auto;pointer-events:none;visibility:hidden}.search-results-overlay[hidden]{display:none!important;pointer-events:none!important;visibility:hidden!important}.search-results-overlay:not(.visible) *,.search-results-overlay[hidden] *{pointer-events:none!important}.search-results-overlay.visible{display:flex;pointer-events:auto;visibility:visible}.search-results-overlay.visible *{pointer-events:auto}.search-results-modal{background-color:var(--color-background-primary);border:1px solid var(--color-background-border);border-radius:0;box-shadow:none;width:min(640px,92vw);max-height:calc(100vh - var(--header-height) - 3rem);overflow:hidden;display:flex;flex-direction:column;padding:0;position:relative;isolation:isolate}.search-results-modal #pagefind-search,.search-results-modal .pagefind-ui{--pagefind-ui-scale: .82;--pagefind-ui-border-radius: 0;--pagefind-ui-image-border-radius: 0;--pagefind-ui-border-width: 1px;--pagefind-ui-font: var(--font-stack);--pagefind-ui-primary: var(--color-brand-primary);--pagefind-ui-text: var(--color-foreground-primary);--pagefind-ui-background: var(--color-background-primary);--pagefind-ui-border: var(--color-background-border);--pagefind-ui-tag: var(--color-background-secondary);width:100%;color:var(--color-foreground-primary);background-color:var(--color-background-primary)}.search-results-modal .pagefind-ui__form{padding:1rem 1rem 0;border-bottom:1px solid var(--color-background-border);background-color:var(--color-background-primary)}.search-results-modal .pagefind-ui__search-input{height:2.75rem;padding:0 3rem 0 2.5rem;font-size:var(--font-size--normal);font-weight:400;letter-spacing:var(--body-letter-spacing);border:1px solid var(--color-background-border);border-radius:0;background-color:var(--color-background-primary);color:var(--color-foreground-primary);transition:all ease .3s}.search-results-modal .pagefind-ui__search-input:focus{outline:none;border-color:var(--color-brand-primary)}.search-results-modal .pagefind-ui__search-clear{height:calc(2.75rem - 6px);border-radius:0;font-size:var(--font-size--small);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.search-results-modal .pagefind-ui__drawer{flex-direction:column;gap:0;padding:0 1rem 1rem;background-color:var(--color-background-primary)}.search-results-modal .pagefind-ui__results-area{margin-top:0;min-width:0;flex:1;background-color:var(--color-background-primary)}.search-results-modal .pagefind-ui__message{font-size:var(--font-size--small);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-foreground-muted);height:auto;padding:.75rem 0;border-bottom:1px solid var(--color-background-border);margin-bottom:0}.search-results-modal .pagefind-ui__results{max-height:min(60vh,520px);overflow-y:auto;overflow-x:hidden;background-color:var(--color-background-primary)}.search-results-modal .pagefind-ui__result{padding:.75rem 0;border-top:1px solid var(--color-background-border)}.search-results-modal .pagefind-ui__result:last-of-type{border-bottom:1px solid var(--color-background-border)}.search-results-modal .pagefind-ui__result-title{font-size:var(--font-size--normal);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.search-results-modal .pagefind-ui__result-link{color:var(--color-foreground-primary);text-decoration:none;transition:all ease .3s}.search-results-modal .pagefind-ui__result-link:hover{color:var(--color-brand-content);text-decoration:underline}.search-results-modal .pagefind-ui__result-excerpt{font-size:var(--font-size--small);line-height:var(--body-line-height);color:var(--color-foreground-secondary);min-width:0;margin-top:.25rem}.search-results-modal .pagefind-ui__result-nested{padding-left:1rem;border-left:1px solid var(--color-background-border);margin-top:.25rem}.search-results-modal .pagefind-ui__result-nested .pagefind-ui__result-link{font-size:var(--font-size--small);font-weight:400;text-transform:none;letter-spacing:var(--body-letter-spacing)}.search-results-modal mark{background-color:var(--color-background-hover);color:var(--color-foreground-primary);padding:.1rem .2rem;border-radius:0;font-weight:600}html[data-theme=dark] .search-results-modal mark{background-color:var(--color-warning);color:#000}.search-results-modal .pagefind-ui__button{border-radius:0;font-size:var(--font-size--small);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:.75rem;height:2.5rem;transition:all ease .3s}.search-results-modal .pagefind-ui__button:hover{background-color:var(--color-background-hover);border-color:var(--color-brand-primary)}[data-theme=dark] .search-results-modal{background-color:var(--color-background-primary)}.header-nav-link.active{color:var(--color-foreground-primary);font-weight:700;text-decoration:underline}.sidebar-group-toggle{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:inherit}.sidebar-tree .parent-reference{display:flex;align-items:center;width:100%;font-weight:700;color:var(--color-sidebar-link-text--top-level);padding:var(--sidebar-item-spacing-vertical) var(--sidebar-item-spacing-horizontal);transition:all ease .3s;border-radius:0}.sidebar-tree .parent-reference:hover{background:var(--color-sidebar-item-background--hover)}.sidebar-tree .child-reference.active,.sidebar-tree .sidebar-link.active{background:var(--color-background-hover);color:var(--color-foreground-primary);font-weight:700}.homepage-intro{margin-bottom:1rem}.search-unavailable-message{margin:0;padding:1rem;color:var(--color-foreground-secondary);font-size:var(--font-size--small);text-align:center}.search-unavailable-message code{font-family:var(--font-stack--monospace);font-size:var(--font-size--small--2)}html[data-theme=dark] .astro-code span{color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.astro-code code,.astro-code span,.astro-code .line{background:transparent!important;background-color:transparent!important}.lesson-content>pre.astro-code,.exercise-box-body>pre.astro-code,#furo-main-content .lesson-content>pre.astro-code{background:var(--color-code-background)!important;border:1px solid var(--color-background-border)!important;border-radius:0;box-shadow:none;color:var(--color-code-foreground);display:block;font-family:var(--font-stack--monospace);font-size:var(--code-font-size);line-height:1.6;margin:1.5rem 0;max-height:calc(100vh - var(--header-height) - 2rem);max-width:100%;overflow:hidden;overflow-x:auto;overflow-y:auto;padding:1.5rem;position:relative;white-space:pre-wrap;word-wrap:break-word}.code-tabs-container pre.astro-code{background:var(--color-code-background)!important;border:none!important;border-radius:0;box-shadow:none;color:var(--color-code-foreground);display:flex;flex-direction:column;font-family:var(--font-stack--monospace);font-size:var(--code-font-size);line-height:1.6;margin:0;max-height:none;max-width:100%;overflow:hidden;overflow-x:auto;overflow-y:auto;padding:1.5rem;position:relative;white-space:pre-wrap;word-wrap:break-word}.lesson-content pre.astro-code code,.exercise-box-body pre.astro-code code,.code-tabs-container pre.astro-code code{background:transparent!important;background-color:transparent!important;border-radius:0;color:inherit;font-family:inherit;font-size:inherit;line-height:inherit;max-width:100%;overflow-wrap:break-word;padding:0!important;white-space:pre-wrap;word-wrap:break-word}.lesson-content>pre:not(.astro-code),.exercise-box-body>pre:not(.astro-code){background:var(--color-background-secondary);border:1px solid var(--color-background-border);border-radius:0;margin:1.5rem 0;overflow-x:auto;padding:1.5rem;font-family:var(--font-stack--monospace);font-size:var(--code-font-size);line-height:1.6}.lesson-content pre:not(.astro-code) code,.exercise-box-body pre:not(.astro-code) code{background:transparent;font-family:inherit;font-size:inherit;line-height:inherit;padding:0}html[data-theme=dark] .lesson-content>pre.astro-code,html[data-theme=dark] .exercise-box-body>pre.astro-code,html[data-theme=dark] #furo-main-content .lesson-content>pre.astro-code{background:var(--color-code-background)!important;border-color:var(--color-background-border)!important}html[data-theme=dark] .code-tabs-container pre.astro-code{background:var(--color-code-background)!important}@media(max-width:48em){.lesson-content>pre.astro-code,.exercise-box-body>pre.astro-code,.code-tabs-container pre.astro-code,.lesson-content>pre:not(.astro-code),.exercise-box-body>pre:not(.astro-code){font-size:.9rem;padding:1rem .75rem}}
