@charset "UTF-8"; @import "tags.css"; /* until browsers don't let us set length values based on dppx, we need a way to calculate them ourself */ :root { --dpr: 1; } @media (min-resolution: 105dpi) { :root { --dpr: 1.1; } } @media (min-resolution: 115dpi) { :root { --dpr: 1.2; } } @media (min-resolution: 120dpi) { :root { --dpr: 1.25; } } @media (min-resolution: 128dpi) { :root { --dpr: 1.333; } } @media (min-resolution: 144dpi) { :root { --dpr: 1.5; } } @media (min-resolution: 160dpi) { :root { --dpr: 1.666; } } @media (min-resolution: 168dpi) { :root { --dpr: 1.75; } } @media (min-resolution: 192dpi) { :root { --dpr: 2; } } @media (min-resolution: 240dpi) { :root { --dpr: 2.5; } } @media (min-resolution: 288dpi) { :root { --dpr: 3; } } @media (min-resolution: 384dpi) { :root { --dpr: 4; } } html { height: 100%; width: 100%; } body { display: flex; flex-direction: row-reverse; /* IE11 to allow body to have initial focus for PS and better SEO and a11y */ font-size: 1.015625rem; font-weight: 300; height: 100%; justify-content: flex-end; line-height: 1.574; /* overflow: hidden; PSC removed for #242 #243 #244; to avoid browser scrollbar to flicker before we create our own */ width: 100%; } b, strong, label, th { font-weight: 600; } ul { list-style: disc; } dt { font-style: italic; } dd { display: list-item; list-style: circle; } .default-animation{ transition: all 0.35s ease; } #sidebar { display: flex; flex-basis: auto; flex-direction: column; flex-grow: 0; flex-shrink: 0; font-size: .953125rem; height: 100%; inset-inline-start: 0; line-height: 1.574; min-height: 100%; min-width: 18.75rem; max-width: 18.75rem; position: fixed; width: 18.75rem; } #header-wrapper { border-bottom-style: solid; border-bottom-width: 4px; text-align: center; padding: 1rem; position: relative; } #header a { display: inline-block; } .searchbox { border-radius: 4px; border-style: solid; border-width: 1px; position: relative; margin-top: 1rem; } .searchbox > :first-child { inset-inline-start: .5rem; position: absolute; } .searchbox > button { -webkit-appearance: none; appearance: none; background-color: transparent; border: 0; margin: 0; padding: 0; top: .25rem; } .searchbox > i { top: .5rem; } .searchbox span { cursor: pointer; inset-inline-end: .5rem; position: absolute; top: .25rem; } #sidebar .searchbox > :first-child, #sidebar .searchbox button, .searchbox span { opacity: .65; } #sidebar .searchbox button:hover, .searchbox span:hover { opacity: 1; } .searchbox input { display: inline-block; width: 100%; height: 1.875rem; background: transparent; border: 0; padding-bottom: 0; padding-inline-end: 1.6rem; padding-inline-start: 1.8rem; padding-top: 0; margin: 0; font-weight: 300; } .searchbox input::placeholder { opacity: .45; } #content-wrapper { --ps-rail-hover-color: rgba( 176, 176, 176, .25 ); display: flex; flex-direction: column; flex: 1; /* fill rest of vertical space */ overflow: hidden; position: relative; /* PS */ z-index: 100; } #sidebar .padding { padding: 0 1rem; } #sidebar ul { list-style: none; padding: 0; margin: 0; } #sidebar ul li { padding: 0; } #sidebar ul li.visited + span { margin-inline-end: 1rem; } #sidebar ul li .read-icon { display: none; font-size: .8125rem; inset-inline-end: 1rem; margin: .25rem 0 0 0; min-width: 1rem; position: absolute; } #sidebar ul li.visited > a .read-icon { display: inline; } #sidebar .nav-title { font-size: 2rem; font-weight: 200; letter-spacing: -.02175em; line-height: 110% !important; margin: 1rem 0 1rem 0; padding-inline-start: 1rem; text-rendering: optimizeLegibility; text-transform: uppercase; } #sidebar .footermargin { margin-top: auto; } #sidebar hr { border-bottom-style: solid; border-bottom-width: 1px; margin: 1.5rem 1rem 1rem 1rem; } #body { display: flex; flex-basis: 100%; flex-direction: column; flex-grow: 1; flex-shrink: 0; height: 100%; margin-inline-start: 18.75rem; min-height: 100%; min-width: calc( 100% - 18.75rem); max-width: calc( 100% - 18.75rem); overflow-wrap: break-word; /* avoid x-scrolling of body if it is to large to fit */ position: relative; /* PS */ width: calc( 100% - 18.75rem); z-index: 70; } #body img:not(.lightbox-image), #body img.center, #body .video-container { display: block; margin: 1.5rem auto; text-align: center; } #body img.left { margin-left: 0; } #body img.right { margin-right: 0; } #body img.border, #body .video-container.border { border: 2px solid rgba( 134, 134, 134, .125 ); } #body img.shadow, #body .video-container.shadow { box-shadow: 0 10px 30px rgba( 176, 176, 176, .666 ); } #body img.inline { display: inline !important; margin: 0 !important; vertical-align: bottom; } #body-inner { display: flex; flex: auto; flex-direction: column; overflow-y: auto; padding: 0 3.25rem 4rem 3.25rem; position: relative; /* PS */ } @media screen and (max-width: 60rem) { #body-inner { padding: 0 2rem 1rem 2rem; } } @media screen and (max-width: 48rem) { #body-inner { padding: 0 1.25rem .375rem 1.25rem; } } #body-inner:focus-visible{ /* remove focus indicator for programatically set focus */ outline: none; } #body h1 + hr { margin-bottom: 2rem; margin-top: -1rem; } #body .flex-block-wrapper { margin-left: auto; margin-right: auto; max-width: calc( 81.25rem - 18.75rem - 2 * 3.25rem ); width: 100%; } body:not(.print) #body .narrow .flex-block-wrapper { max-width: calc( 81.25rem - 18.75rem - 2 * 9.75rem ); } /* we limit width if we have large screens */ @media screen and ( min-width: 81.25rem ){ /* #sidebar/width + ./max-width */ #body .flex-block-wrapper { width: calc( 81.25rem - 18.75rem - 2 * 3.25rem ); } body:not(.print) #body .narrow .flex-block-wrapper { width: calc( 81.25rem - 18.75rem - 2 * 9.75rem ); } } body:not(.print) #body-inner.narrow { padding: 2rem 9.75rem; } @media screen and (max-width: 60rem) { body:not(.print) #body-inner.narrow { padding: 1rem 6.5rem; } } @media screen and (max-width: 48rem) { body:not(.print) #body-inner.narrow { padding: .375rem 3.25rem; } } #body-inner div.article-subheading, #body-inner .chapter.deprecated h3:first-of-type { font-weight: 200; margin-top: 0; text-align: center; } body:not(.print) #body-inner.narrow p { font-size: 1.2rem; text-align: justify; } mark { color: rgba( 0, 0, 0, 1 ); } h1 { font-size: 3.25rem; font-weight: 200; margin: 0.85rem 0 1rem 0; /* big titles cause a horizontal scrollbar - fixing this by wrapping text */ overflow-wrap: break-word; overflow-x: hidden; text-align: center; text-rendering: optimizeLegibility; text-transform: uppercase; } body:not(.print) #body-inner.narrow h1 { border-bottom: 4px solid rgba( 134, 134, 134, .125 ); font-size: 3.5rem; } @media only screen and (min-width: 48rem) and (max-width: 60rem) { body:not(.print) #body-inner.narrow h1 { font-size: 2.8rem; } } @media only screen and (max-width: 48rem) { body:not(.print) #body-inner.narrow h1 { font-size: 2.5rem; } } h2 { font-size: 2.2rem; font-weight: 500; } h3, .article-subheading { font-size: 1.8rem; font-weight: 500; } h4 { font-size: 1.85rem; font-weight: 300; } h5 { font-size: 1.6rem; font-weight: 300; } h6 { font-size: 1.3rem; font-weight: 300; } h2, h3, .article-subheading, h4, h5, h6 { letter-spacing: -.0625rem; margin: 2rem 0 1rem 0; /* big titles cause a horizontal scrollbar - fixing this by wrapping text */ overflow-wrap: break-word; overflow-x: hidden; text-rendering: optimizeLegibility; } h2, h3, h4, h5, h6 { /* leave space for anchor to avoid overflow */ padding-inline-end: 2rem; } blockquote { border-inline-start: .6rem solid rgba( 134, 134, 134, .4 ); } blockquote p { font-size: 1.06640625rem; font-style: italic; opacity: .75; text-align: justify; } blockquote cite { display: block; font-weight: bold; opacity: .5; padding-top: .5rem; text-align: end; } /* colored boxes */ .cstyle { --VARIABLE-BOX-color: var(--INTERNAL-BOX-NEUTRAL-color); --VARIABLE-BOX-CAPTION-color: var(--INTERNAL-BOX-CAPTION-color); --VARIABLE-BOX-BG-color: var(--INTERNAL-BOX-BG-color); --VARIABLE-BOX-TEXT-color: var(--INTERNAL-BOX-NEUTRAL-TEXT-color); -webkit-print-color-adjust: exact; color-adjust: exact; } div.box { margin: 1.5rem 0; border-style: solid; border-width: 1px; } div.box > .box-label { font-weight: 500; padding: .2rem .6rem; } div.box > .box-content { padding-top: 1rem; padding-bottom: 1rem; padding-left: 1rem; padding-right: 1rem; } #body table th > :first-child, #body table th > :first-child :first-child, #body table td > :first-child, #body table td > :first-child :first-child, #body div.box > .box-content > :first-child, #body div.box > .box-content > :first-child :first-child, #body div.expand > .expand-content-text > :first-child, #body div.expand > .expand-content-text > :first-child :first-child, #body div.tab-content > .tab-content-text > :first-child, #body div.tab-content > .tab-content-text > :first-child :first-child { margin-top: 0; } #body table th > :last-child, #body table th > :last-child :last-child, #body table td > :last-child, #body table td > :last-child :last-child, #body div.box > .box-content > :last-child, #body div.box > .box-content > :last-child :last-child, #body div.expand > .expand-content-text > :last-child, #body div.expand > .expand-content-text > :last-child :last-child, #body div.tab-content > .tab-content-text > :last-child, #body div.tab-content > .tab-content-text > :last-child :last-child { margin-bottom: 0; } /* attachments shortcode */ div.attachments .box-content { display: block; margin: 0; padding-inline-start: 1.75rem; } /* Children shortcode */ .children p { font-size: .8125rem; margin-bottom: 0; margin-top: 0; padding-bottom: 0; padding-top: 0; } .children-li p { font-size: .8125rem; font-style: italic; } .children-h2 p, .children-h3 p { font-size: .8125rem; margin-bottom: 0; margin-top: 0; padding-bottom: 0; padding-top: 0; } #body-inner .children h2, #body-inner .children h3, #body-inner .children h4, #body-inner .children h5, #body-inner .children h6 { margin-bottom: 0; margin-top: 1rem; } #body-inner ul.children-h2, #body-inner ul.children-h3, #body-inner ul.children-h4, #body-inner ul.children-h5, #body-inner ul.children-h6 { /* if we display children with style=h2 but without a containerstyle a ul will be used for structuring; we remove default indention for uls in this case */ padding-inline-start: 0; } code, kbd, pre, samp { font-size: .934375rem; vertical-align: baseline; } code { border-radius: 2px; border-style: solid; border-width: 1px; -webkit-print-color-adjust: economy; color-adjust: economy; padding-left: 2px; padding-right: 2px; white-space: nowrap; } span.copy-to-clipboard { display: inline-block; white-space: nowrap; } code.copy-to-clipboard-code { border-end-end-radius: 0; border-start-end-radius: 0; border-inline-end-width: 0; } pre { border-radius: 2px; border-style: solid; border-width: 1px; -webkit-print-color-adjust: economy; color-adjust: economy; line-height: 1.15; padding: 1rem; position: relative; } /* pre:has( code ), */ /* the :has() operator isn't available in FF yet, so we patch this by JS */ pre.pre-code { direction: ltr; text-align: left; } pre code { background-color: inherit; border: 0; color: inherit; -webkit-print-color-adjust: economy; color-adjust: economy; font-size: .9375rem; margin: 0; padding: 0; white-space: inherit; } hr { border-bottom: 4px solid rgba( 134, 134, 134, .125 ); } #body-inner pre { white-space: pre-wrap; } table { border: 1px solid rgba( 134, 134, 134, .333 ); margin-bottom: 1rem; margin-top: 1rem; table-layout: auto; } th, thead td { background-color: rgba( 134, 134, 134, .166 ); border: 1px solid rgba( 134, 134, 134, .333 ); -webkit-print-color-adjust: exact; color-adjust: exact; padding: 0.5rem; } td { border: 1px solid rgba( 134, 134, 134, .333 ); padding: 0.5rem; } .tooltipped { position: relative; } .tooltipped:after { background: rgba( 0, 0, 0, 1 ); border: 1px solid rgba( 119, 119, 119, 1 ); border-radius: 3px; color: rgba( 255, 255, 255, 1 ); content: attr(aria-label); display: none; font-family: "Work Sans", "Helvetica", "Tahoma", "Geneva", "Arial", sans-serif; font-size: .6875rem; font-weight: normal; -webkit-font-smoothing: subpixel-antialiased; letter-spacing: normal; line-height: 1.5; padding: 5px 8px; pointer-events: none; position: absolute; text-align: center; text-decoration: none; text-shadow: none; text-transform: none; white-space: pre; word-wrap: break-word; z-index: 140; } .tooltipped:before { border: 5px solid transparent; color: rgba( 0, 0, 0, 1 ); content: ""; display: none; height: 0; pointer-events: none; position: absolute; width: 0; z-index: 150; } .tooltipped:hover:before, .tooltipped:hover:after, .tooltipped:active:before, .tooltipped:active:after, .tooltipped:focus:before, .tooltipped:focus:after { display: inline-block; text-decoration: none; } .tooltipped-s:after, .tooltipped-se:after, .tooltipped-sw:after { margin-top: 5px; right: 50%; top: 100%; } .tooltipped-s:before, .tooltipped-se:before, .tooltipped-sw:before { border-bottom-color: rgba( 0, 0, 0, .8 ); bottom: -5px; margin-right: -5px; right: 50%; top: auto; } .tooltipped-se:after { left: 50%; margin-left: -15px; right: auto; } .tooltipped-sw:after { margin-right: -15px; } .tooltipped-n:after, .tooltipped-ne:after, .tooltipped-nw:after { bottom: 100%; margin-bottom: 5px; right: 50%; } .tooltipped-n:before, .tooltipped-ne:before, .tooltipped-nw:before { border-top-color: rgba( 0, 0, 0, .8 ); bottom: auto; margin-right: -5px; right: 50%; top: -5px; } .tooltipped-ne:after { left: 50%; margin-left: -15px; right: auto; } .tooltipped-nw:after { margin-right: -15px; } .tooltipped-s:after, .tooltipped-n:after { transform: translateX(50%); } .tooltipped-w:after { bottom: 50%; margin-right: 5px; right: 100%; transform: translateY(50%); } .tooltipped-w:before { border-left-color: rgba( 0, 0, 0, .8 ); bottom: 50%; left: -5px; margin-top: -5px; top: 50%; } .tooltipped-e:after { bottom: 50%; left: 100%; margin-left: 5px; transform: translateY(50%); } .tooltipped-e:before { border-right-color: rgba( 0, 0, 0, .8 ); bottom: 50%; margin-top: -5px; right: -5px; top: 50%; } #sidebar .highlightable { padding: 1rem 0 1rem; position: relative; } #topbar { min-height: 3rem; position: relative; z-index: 170; } #topbar > div { background-color: rgba( 134, 134, 134, .066 ); height: 100%; } .navigation, #top-print-link, #top-github-link { display: block; float: right; } html[dir="rtl"] .navigation, html[dir="rtl"] #top-print-link, html[dir="rtl"] #top-github-link { float: left; } .nav, .print-link, .github-link { border-inline-start: thin solid rgba( 134, 134, 134, .333 ); padding-left: 1rem; padding-right: 1rem; } html[dir="rtl"] .nav i { transform: scaleX(-1); } span.nav i{ color: rgba( 134, 134, 134, .333 ); } .navigation, #top-print-link, #top-github-link { position: relative; top: 50%; transform: translateY(-50%); } #toc-menu{ cursor: pointer; } #toc-menu, #sidebar-toggle-span { border-inline-end: thin solid rgba( 134, 134, 134, .333 ); padding-left: 1rem; padding-right: 1rem; } #body #breadcrumbs { float: left; height: auto; line-height: 1.4; margin-bottom: 0; overflow: hidden; position: relative; text-overflow: ellipsis; top: 50%; transform: translateY(-50%); white-space: nowrap; width: calc(100% - 5*3.25rem); } html[dir="rtl"] #body #breadcrumbs { float: right; } @media screen and (max-width: 48rem) { #body #breadcrumbs { text-overflow: unset; } } #sidebar-toggle-span { display: none; } .progress { inset-inline-start: 1rem; top: 1rem; } @media screen and (max-width: 48rem) { .mobile-support #sidebar-toggle-span { display: inline; } .progress { inset-inline-start: 4.25rem; } } #body #breadcrumbs .links { display: inline; padding: 0 .75rem; } @media screen and (max-width: 48rem) { #body #breadcrumbs .links { /* we just hide the breadcrumbs instead of display: none; this makes sure that the breadcrumbs are still usable for accessability */ visibility: hidden; } } #body #breadcrumbs .links * { display: inline-block; padding: 0; } #body #breadcrumbs .links meta { display: none; } #body #breadcrumbs .links li:last-of-type { cursor: text; } #body a[aria-disabled="true"] { pointer-events: none; text-decoration: none; } @media screen and (max-width: 60rem) { #sidebar { min-width: 14.375rem; max-width: 14.375rem; width: 14.375rem; } #body { margin-inline-start: 14.375rem; min-width: calc( 100% - 14.375rem); max-width: calc( 100% - 14.375rem); width: calc( 100% - 14.375rem); } } @media screen and (max-width: 48rem) { /* we don't support sidebar flyout in mobile */ .mobile-support #sidebar { inset-inline-start: -14.375rem; } .mobile-support #navshow{ display: inline; } .mobile-support #body { min-width: 100%; max-width: 100%; width: 100%; } .mobile-support #body { margin-inline-start: 0; } .mobile-support.sidebar-flyout { overflow: hidden; } .mobile-support.sidebar-flyout #sidebar { inset-inline-start: 0; z-index: 90; } .mobile-support.sidebar-flyout #body { margin-inline-start: 14.375rem; overflow: hidden; } .mobile-support.sidebar-flyout #sidebar-overlay{ background-color: rgba( 134, 134, 134, .5 ); bottom: 0; cursor: pointer; left: 0; position: absolute; right: 0; top: 0; z-index: 190; } } .copy-to-clipboard-button { border-start-start-radius: 0; border-start-end-radius: 2px; border-end-end-radius: 2px; border-end-start-radius: 0; border-style: solid; border-width: 1px; cursor: pointer; font-size: .934375rem; } span > .copy-to-clipboard-button { border-start-start-radius: 0; border-start-end-radius: 2px; border-end-end-radius: 2px; border-end-start-radius: 0; } .copy-to-clipboard-button > i { font-size: .859625rem; font-weight: 500; } .copy-to-clipboard-code + .copy-to-clipboard-button > i { padding-left: 5px; padding-right: 5px; } pre > .copy-to-clipboard-button { background-color: rgba( 160, 160, 160, .2 ); border-radius: 2px; border-style: solid; border-width: 1px; inset-inline-end: 4px; padding: 5px 3px; position: absolute; top: 4px; } .disableInlineCopyToClipboard span > code.copy-to-clipboard-code + span.copy-to-clipboard-button { display: none; } .disableInlineCopyToClipboard span > code.copy-to-clipboard-code { border-start-end-radius: 2px; border-end-end-radius: 2px; border-inline-end-width: 1px; } #homelinks { border-bottom-style: solid; border-bottom-width: 4px; padding: .5rem 0; } option { color: initial; } .expand { margin-bottom: 1rem; margin-top: 1rem; position: relative; } .expand > input { -webkit-appearance: none; appearance: none; cursor: pointer; } .expand > label { cursor: pointer; display: inline; font-weight: 300; inset-inline-start: 0; line-height: 1.1; margin-top: .2rem; position: absolute; } .expand > label:after { content: ""; display: block; height: 1px; width: 0%; transition: width 0.5s ease; } .expand > label:hover:after { width: 100%; } .expand > label > .fas { font-size: .8rem; width: .6rem; } .expand > .expand-content { margin-inline-start: 1rem; margin-top: .5rem; } /* closed expander */ .expand > input + label + div { display: none; } .expand > input + label > .fa-chevron-down { display: none; } .expand > input + label > .fa-chevron-right { display: inline-block; } /* open expander */ .expand > input:checked + label + div { display: block; } .expand > input:checked + label > .fa-chevron-down { display: inline-block; } .expand > input:checked + label > .fa-chevron-right { display: none; } /* adjust expander for RTL reading direction */ html[dir="rtl"] .expand > .expand-label > i.fa-chevron-right { transform: scaleX(-1); } #body footer.footline{ margin-top: 2rem; } .headline i, .footline i{ margin-inline-start: .5rem; } .headline i:first-child, .footline i:first-child{ margin-inline-start: 0; } .mermaid-container { margin-bottom: 1.7rem; margin-top: 1.7rem; } .mermaid > svg { border: 1px solid transparent; /* remove inline height from generated diagram */ height: initial !important; } .mermaid.zoom > svg { cursor: pointer; } .mermaid.zoom > svg:hover { border-color: rgba( 134, 134, 134, .333 ); } .mermaid-code { display: none; } .include.hide-first-heading h1:first-of-type, .include.hide-first-heading h2:first-of-type, .include.hide-first-heading h3:first-of-type, .include.hide-first-heading h4:first-of-type, .include.hide-first-heading h5:first-of-type, .include.hide-first-heading h6:first-of-type { display: none; } .include.hide-first-heading h1 + h2:first-of-type, .include.hide-first-heading h1 + h3:first-of-type, .include.hide-first-heading h2 + h3:first-of-type, .include.hide-first-heading h1 + h4:first-of-type, .include.hide-first-heading h2 + h4:first-of-type, .include.hide-first-heading h3 + h4:first-of-type, .include.hide-first-heading h1 + h5:first-of-type, .include.hide-first-heading h2 + h5:first-of-type, .include.hide-first-heading h3 + h5:first-of-type, .include.hide-first-heading h4 + h5:first-of-type, .include.hide-first-heading h1 + h6:first-of-type, .include.hide-first-heading h2 + h6:first-of-type, .include.hide-first-heading h3 + h6:first-of-type, .include.hide-first-heading h4 + h6:first-of-type, .include.hide-first-heading h5 + h6:first-of-type { display: block; } #body a.highlight, #body a.highlight:hover, #body a.highlight:focus { outline-style: none; text-decoration: none; } #body a.highlight { display: inline-block; line-height: 1.1; } #body a.highlight:after { content: ""; display: block; height: 1px; width: 0%; transition: width 0.5s ease; } #body a.highlight:hover:after, #body a.highlight:focus:after { width: 100%; } #body #topbar .navigation a.highlight:after, #body #sidebar-toggle-span a.highlight:after, #body #top-print-link a.highlight:after, #body #top-github-link a.highlight:after { background-color: transparent; } /* Table of contents */ .toc-flyout #toc-overlay{ bottom: 0; cursor: pointer; left: 0; position: absolute; right: 0; top: 0; z-index: 160; } .progress { border: 0 solid rgba( 134, 134, 134, .166 ); box-shadow: 1px 2px 5px 1px rgba( 134, 134, 134, .2 ); height: 0; opacity: 0; overflow: hidden; position: absolute; width: 0; z-index: 180; } .toc-flyout .progress { border-width: 1px; height: auto; opacity: 1; width: auto; } .progress .toc-wrapper { background-color: rgba( 134, 134, 134, .066 ); } .progress ul { list-style: none; margin: 0; padding: 0 1rem; } #TableOfContents { --ps-rail-hover-color: rgba( 176, 176, 176, .25 ); font-size: .8125rem !important; max-height: 90vh; overflow: hidden; padding: 1rem .375rem !important; position: relative; /* PS */ } #TableOfContents > ul > li > a { font-weight: 500; } .btn { border-radius: 4px; cursor: pointer; display: inline-block; font-size: .9rem; font-weight: 500; line-height: 1.1; margin-bottom: 0; touch-action: manipulation; -ms-user-select: none; -webkit-user-select: none; user-select: none; } .btn > :where(button) { -webkit-appearance: none; appearance: none; border-width: 0; margin: 0; padding: 0; } .btn > * { background-color: transparent; border-radius: 4px; border-style: solid; border-width: 1px; padding: 6px 12px; text-align: center; touch-action: manipulation; -ms-user-select: none; -webkit-user-select: none; user-select: none; white-space: nowrap; } .btn > *:after { /* avoid breakage if no content is given */ content: "\200b" } #body #body-inner .btn > *.highlight:after { background-color: transparent; } .btn > *:focus { outline: none; } .btn > *:hover, .btn > *:focus { text-decoration: none; } /* anchors */ .anchor { cursor: pointer; font-size: .5em; margin-inline-start: .66em; margin-top: .9em; position: absolute; visibility: hidden; } h2:hover .anchor, h3:hover .anchor, h4:hover .anchor, h5:hover .anchor, h6:hover .anchor { visibility: visible; } /* Redfines headers style */ h1 a, h2 a, h3 a, h4 a, h5 a, h6 a { font-weight: inherit; } #body h1 + h2, #body h1 + h3, #body h1 + h4, #body h1 + h5, #body h1 + h6, #body h2 + h3, #body h2 + h4, #body h2 + h5, #body h2 + h6, #body h3 + h4, #body h3 + h5, #body h3 + h6, #body h4 + h5, #body h4 + h6, #body h5 + h6 { margin-top: 1rem; } .select-container i { padding-top: .25em; } .select-container i, .select-container span { display: block; float: left; } html[dir="rtl"] .select-container i, html[dir="rtl"] .select-container span { float: right; } #sidebar ul select { padding-left: 0; padding-right: 0; } .select-style { border: 0; border-radius: 0; height: 1.574em; overflow: hidden; } .select-style select { -webkit-appearance: none; appearance: none; border: none; box-shadow: none; background-color: transparent; background-image: none; width: 100%; } .select-style select:focus { outline: none; } .select-style :hover { cursor: pointer; } .select-style option { color: rgba( 0, 0, 0, 1 ); padding: 0; margin: 0; } .select-clear { clear: both; } .footerLangSwitch, .footerVariantSwitch, .footerVisitedLinks, .footerFooter { display: none; } .showLangSwitch, .showVariantSwitch, .showVisitedLinks, .showFooter { display: initial; } .footerVisitedLinks > * { -webkit-appearance: none; appearance: none; background: transparent; cursor: pointer; text-align: start; text-decoration: none; width: 100%; } @media screen and (max-width: 48rem) { #breadcrumbs .links { display: none; } } /* clears the 'X' from Chrome's search input */ input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-results-button, input[type="search"]::-webkit-search-results-decoration { display: none; } .math.align-left > mjx-container{ text-align: left !important; } .math.align-center > mjx-container{ text-align: center !important; } .math.align-right > mjx-container{ text-align: right !important; } .scrollbar-measure { /* https://davidwalsh.name/detect-scrollbar-width */ height: 100px; overflow: scroll; position: absolute; width: 100px; top: -9999px; } .a11y-only { /* idea taken from https://www.filamentgroup.com/lab/a11y-form-labels.html */ clip: rect(1px,1px,1px,1px); overflow: hidden; position: absolute; height: 1px; transform: translateY(-100%); transition: transform .5s cubic-bezier(.18,.89,.32,1.28); white-space: nowrap; width: 1px; } /* filament style for making action visible on focus - not adepted yet .a11y-only:focus { position: fixed; height: auto; overflow: visible; clip: auto; white-space: normal; margin: 0 0 0 -100px; top: -.3em; left: 50%; text-align: center; width: 200px; background: rgba( 255, 255, 255, 1 ); color: rgba( 54, 133, 18, 1 ); padding: .8em 0 .7em; font-size: 16px; z-index: 5000; text-decoration: none; border-bottom-right-radius: 8px; border-bottom-left-radius: 8px; outline: 0; transform: translateY(0%); } */ .mermaid-container .align-right > * { display: block; margin-left: auto; margin-right: 0; } .mermaid-container .align-center > * { display: block; margin-left: auto; margin-right: auto; } .mermaid-container .align-left > * { display: block; margin-left: 0; margin-right: auto; } .searchform { display: flex; } .searchform input { flex: 1 0 60%; border-radius: 4px; border: 2px solid rgba( 134, 134, 134, .125 ); background: rgba( 134, 134, 134, .125 ); display: block; margin: 0; margin-inline-end: .5rem; } .searchform input::-webkit-input-placeholder, .searchform input::placeholder { color: rgba( 134, 134, 134, 1 ); opacity: .666; } .searchform .btn { display: inline-flex; } .searchhint { margin-top: 1rem; height: 1.5rem; } #searchresults a.autocomplete-suggestion { display: block; font-size: 1.3rem; font-weight: 500; line-height: 1.5rem; padding: 1rem; } #searchresults a.autocomplete-suggestion:after { height: 0; } #searchresults .autocomplete-suggestion > .context { font-size: 1rem; font-weight: 300; margin-top: .66rem; } .badge { border-radius: 3px; display: inline-block; font-size: .8rem; font-weight: 500; vertical-align: middle; } .badge > * { border-radius: 3px; border-style: solid; border-width: 1px; display: inline-block; padding: 0 .25rem } .badge > .badge-title { background-color: rgba( 16, 16, 16, 1 ); border-inline-end: 0; border-start-end-radius: 0; border-end-end-radius: 0; color: rgba( 240, 240, 240, 1 ); filter: contrast(2); opacity: .75; } .badge.badge-with-title > .badge-content { border-start-start-radius: 0; border-end-start-radius: 0; } .badge-content:after { /* avoid breakage if no content is given */ content: "\200b"; } /* task list and its checkboxes */ article ul > li:has(> input[type="checkbox"]) { list-style: none; margin-inline-start: -1rem; } article ul > li:has(> input[type="checkbox"])::before { content: "\200B"; /* accessibilty for Safari https://developer.mozilla.org/en-US/docs/Web/CSS/list-style */ } /* https://moderncss.dev/pure-css-custom-checkbox-style/ */ article ul > li > input[type="checkbox"] { -webkit-appearance: none; appearance: none; /* For iOS < 15 */ border: 0.15em solid currentColor; border-radius: 0.15em; display: inline-grid; font: inherit; height: 1.15em; margin: 0; place-content: center; transform: translateY(-0.075em); width: 1.15em; } article ul > li > input[type="checkbox"]::before { box-shadow: inset 1em 1em var(--INTERNAL-PRIMARY-color); clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%); content: ""; height: 0.65em; transform: scale(0); transform-origin: bottom left; transition: 120ms transform ease-in-out; width: 0.65em; /* Windows High Contrast Mode fallback must be last */ background-color: CanvasText; } article ul > li > input[type="checkbox"]:checked::before { transform: scale(1); } /* CSS Lightbox https://codepen.io/gschier/pen/kyRXVx */ .lightbox { align-items: center; background: rgba( 0, 0, 0, .8 ); bottom: 0; display: none; justify-content: center; left: 0; position: fixed; right: 0; text-align: center; top: 0; white-space: nowrap; z-index: 1999; } .lightbox:target { display: flex; } .lightbox img { max-height: 95%; max-width: 95%; overflow: auto; padding: min(2vh, 2vw); } /* basic menu list styles (non-collapsible) */ #sidebar ul > li > a { display: block; position: relative; } #sidebar ul.space > li > * { padding-bottom: .125rem; padding-top: .125rem; } #sidebar ul.space > li > ul { padding-bottom: 0; padding-top: 0; } #sidebar ul.morespace > li > * { padding-bottom: .25rem; padding-top: .25rem; } #sidebar ul.morespace > li > ul { padding-bottom: 0; padding-top: 0; } #sidebar ul.enlarge > li > a { font-size: 1.1rem; line-height: 2rem; } #sidebar ul.enlarge > li > a > .read-icon { margin-top: .5rem; } #sidebar ul.enlarge > li > ul > li:last-child { padding-bottom: 1rem; } #sidebar ul ul { padding-inline-start: 1rem; } /* collapsible menu style overrides */ #sidebar ul.collapsible-menu > li { position: relative; } #sidebar ul.collapsible-menu > li > input { -webkit-appearance: none; appearance: none; cursor: pointer; display: inline-block; margin-left: 0; margin-right: 0; margin-top: .65rem; position: absolute; width: 1rem; z-index: 1; } #sidebar ul.collapsible-menu.enlarge > li > input { margin-top: .9rem; } #sidebar ul.collapsible-menu > li > label { cursor: pointer; display: inline-block; inset-inline-start: 0; margin-bottom: 0; /* nucleus */ padding-inline-start: .125rem; position: absolute; width: 1rem; z-index: 2; } #sidebar ul.collapsible-menu.enlarge > li > label { font-size: 1.1rem; line-height: 2rem; } #sidebar ul.collapsible-menu > li > label:after { content: ""; display: block; height: 1px; transition: width 0.5s ease; width: 0%; } #sidebar ul.collapsible-menu > li > label:hover:after { width: 100%; } #sidebar ul.collapsible-menu > li > label > .fas { font-size: .8rem; width: .6rem; } #sidebar ul.collapsible-menu > li > a { display: inline-block; width: 100%; } /* menu states for not(.collapsible-menu) */ #sidebar ul ul { display: none; } #sidebar ul > li.parent > ul, #sidebar ul > li.active > ul, #sidebar ul > li.alwaysopen > ul { display: block; } /* closed menu */ #sidebar ul.collapsible-menu > li > input + label ~ ul { display: none; } #sidebar ul.collapsible-menu > li > input + label > .fa-chevron-down { display: none; } #sidebar ul.collapsible-menu > li > input + label > .fa-chevron-right { display: inline-block; } /* open menu */ #sidebar ul.collapsible-menu > li > input:checked + label ~ ul { display: block; } #sidebar ul.collapsible-menu > li > input:checked + label > .fa-chevron-down { display: inline-block; } #sidebar ul.collapsible-menu > li > input:checked + label > .fa-chevron-right { display: none; } /* adjust menu for RTL reading direction */ html[dir="rtl"] #sidebar ul.collapsible-menu > li > label > i.fa-chevron-right { transform: scaleX(-1); } .columnize{ column-count: 2; } @media screen and (min-width: 79.25rem) { .columnize{ column-count: 3; } } #body .tab-panel{ margin-bottom: 1.5rem; margin-top: 1.5rem; } #body .tab-nav{ display: flex; flex-wrap: wrap; } #body .tab-nav-button{ background-color: transparent; border: 1px solid transparent; display: block; font-size: .9rem; font-weight: 300; line-height: 1.42857143; margin-inline-start: .6rem; } #body .tab-nav-button.active{ border-radius: 2px 2px 0 0; cursor: default; } #body .tab-nav-button.active > *{ border-radius: 1px 1px 0 0; } #body .tab-nav-button > * > *{ border-bottom-style: solid; border-bottom-width: 2px; padding: .2rem .6rem; } #body .tab-nav-button.active > * > *{ border-bottom-color: transparent; font-weight: 500; } #body .tab-content{ border-style: solid; border-width: 1px; display: none; /* if setting a border to 1px, a browser instead sets it to 1dppx which is not usable as a unit yet, so we have to calculate it ourself */ margin-top: calc( -1px / var(--dpr) ); z-index: 10; } #body .tab-content.active{ display: block; } #body .tab-content-text{ padding: 1rem; } /* remove margin if only a single code block is contained in the tab */ #body .tab-content-text:has(> div.highlight:only-child){ padding: 0; } /* remove border from a code block if single */ #body .tab-content-text > div.highlight:only-child > pre{ border: 0; } #body .tab-content-text pre{ margin-bottom: 0; margin-top: 0; }