@import url(https://fonts.googleapis.com/css?family=Open+Sans:300i,400,700); @import url('https://rsms.me/inter/inter.css'); @import url('jetbrains-mono.css'); :root { --default-gray: #f4f4f4; --breadcrumb-font-color: #637282; --breadcrumb-margin: 24px; --hover-link-color: #5B5DEF; --footer-height: 64px; --footer-padding-top: 48px; --footer-background: var(--default-gray); --horizontal-spacing-for-content: 16px; --mobile-horizontal-spacing-for-content: 8px; --bottom-spacing: 16px; --color-scrollbar: rgba(39, 40, 44, 0.40); --color-scrollbar-track: var(--default-gray); --default-white: #fff; --background-color: var(--default-white); --color-dark: #27282c; --default-font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Droid Sans, Helvetica Neue, Arial, sans-serif; --default-monospace-font-family: SFMono-Regular, Consolas, Liberation Mono, Menlo, Courier, monospace; --default-font-size: 15px; --average-color: var(--color-dark); --secondary-text-color: rgba(39, 40, 44, .7); --code-background: rgba(39, 40, 44, .05); --border-color: rgba(39, 40, 44, .2); --top-navigation-height: 67px; --max-width: 1160px; } html { height: 100%; -webkit-tap-highlight-color: rgba(0, 0, 0, 0); scrollbar-color: rgba(39, 40, 44, 0.40) #F4F4F4; scrollbar-color: var(--color-scrollbar) var(--color-scrollbar-track); text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; } html ::-webkit-scrollbar { width: 8px; height: 8px; } html ::-webkit-scrollbar-track { background-color: var(--color-scrollbar-track); } html ::-webkit-scrollbar-thumb { width: 8px; border-radius: 6px; background: rgba(39, 40, 44, 0.40); background: var(--color-scrollbar); } .main-content { padding-bottom: var(--bottom-spacing); z-index: 0; max-width: var(--max-width); width: 100%; margin-left: auto; margin-right: auto; } .main-content > * { margin-left: var(--horizontal-spacing-for-content); margin-right: var(--horizontal-spacing-for-content); } .navigation-wrapper { display: flex; flex-wrap: wrap; position: sticky; top: 0; background-color: var(--color-dark); z-index: 4; color: #fff; font-family: var(--default-font-family); letter-spacing: -0.1px; /* Reset margin and use padding for border */ margin-left: 0; margin-right: 0; padding: 19px var(--horizontal-spacing-for-content) 18px; } .navigation-wrapper > .library-name { font-weight: 700; margin-right: 12px; } .navigation-wrapper a { color: #fff; } #searchBar { margin-left: 16px; } .breadcrumbs, .breadcrumbs a, .breadcrumbs a:hover { margin-top: var(--breadcrumb-margin); color: var(--breadcrumb-font-color); overflow-wrap: break-word; } .tabs-section > .section-tab:first-child, .platform-hinted > .platform-bookmarks-row > .platform-bookmark:first-child { margin-left: 0; } .section-tab { border: 0; background-color: transparent; border-bottom: 1px solid #DADFE6; } .platform-hinted > .platform-bookmarks-row { margin-bottom: 16px; } .section-tab, .platform-hinted > .platform-bookmarks-row > .platform-bookmark { margin: 0 8px; padding: 11px 3px; cursor: pointer; outline: none; font-size: var(--default-font-size); color: var(--average-color); } .section-tab:hover { color: #282E34; border-bottom: 2px solid var(--hover-link-color); } .section-tab[data-active=''] { color: #282E34; border-bottom: 2px solid var(--hover-link-color); } .tabs-section-body { background-color: white; } .tabs-section-body > div { margin-top: 12px; } .tabs-section-body .with-platform-tabs { padding-top: 12px; padding-bottom: 12px; } .cover > .platform-hinted { padding-top: 12px; margin-top: 12px; padding-bottom: 12px; } .cover { display: flex; flex-direction: column; } .cover .platform-hinted.with-platform-tabs .sourceset-depenent-content > .block ~ .symbol { padding-top: 16px; padding-left: 0; } .cover .sourceset-depenent-content > .block { padding: 16px 0; font-size: 18px; line-height: 28px; } .cover .platform-hinted.with-platform-tabs .sourceset-depenent-content > .block { padding: 0; font-size: var(--default-font-size); } .cover ~ .divergent-group { margin-top: 24px; padding: 24px 8px 8px 8px; } .cover ~ .divergent-group .main-subrow .symbol { width: 100%; } .cover p.paragraph { margin-top: 8px; } .divergent-group { background-color: var(--background-color); padding: 8px 0 8px 0; margin-bottom: 2px; } .divergent-group .table-row, tbody > tr { border-bottom: 1px solid var(--border-color); } .divergent-group .table-row:last-of-type, tbody > tr:last-of-type { border-bottom: none; } .title > .divergent-group:first-of-type { padding-top: 0; } #container { display: flex; flex-direction: row; height: calc(100% - var(--top-navigation-height)); } #container > div { height: 100%; max-height: calc(100vh - var(--top-navigation-height)); overflow: auto; } #main { width: 100%; max-width: calc(100% - 280px); display: flex; flex-direction: column; } #leftColumn { width: 280px; border-right: 1px solid var(--border-color); display: flex; flex-direction: column; } #sideMenu { padding-top: 22px; overflow-y: auto; font-size: 12px; font-weight: 400; line-height: 16px; height: 100%; } .sample-container, div.CodeMirror { display: flex; flex-direction: column; } code.paragraph { display: block; } .overview > .navButton { align-items: center; display: flex; justify-content: flex-end; padding: 2px 2px 2px 0; margin-right: 5px; cursor: pointer; } .strikethrough { text-decoration: line-through; } .symbol:empty { padding: 0; } .symbol, code { background-color: var(--code-background); align-items: center; box-sizing: border-box; white-space: pre-wrap; font-family: var(--default-monospace-font-family); font-size: var(--default-font-size); } .symbol, code.block { display: block; padding: 12px 32px 12px 12px; border-radius: 8px; line-height: 24px; } .symbol > a { color: var(--hover-link-color); } .copy-icon { cursor: pointer; } .symbol span.copy-icon { display: none; } .symbol:hover span.copy-icon { display: inline-block; } .symbol span.copy-icon::before { width: 24px; height: 24px; display: inline-block; content: ''; /* masks are required if you want to change color of the icon dynamically instead of using those provided with the SVG */ -webkit-mask: url("../images/copy-icon.svg") no-repeat 50% 50%; mask: url("../images/copy-icon.svg") no-repeat 50% 50%; -webkit-mask-size: cover; mask-size: cover; background-color: var(--secondary-text-color); } .symbol span.copy-icon:hover::before { background-color: var(--color-dark); } .copy-popup-wrapper { display: none; align-items: center; position: absolute; z-index: 1000; background: white; font-weight: normal; font-family: 'Inter', "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif; width: max-content; font-size: var(--default-font-size); cursor: default; border: 1px solid #D8DCE1; box-sizing: border-box; box-shadow: 0px 5px 10px var(--ring-popup-shadow-color); border-radius: 3px; } .copy-popup-wrapper > .copy-popup-icon::before { content: url("../images/copy-successful-icon.svg"); padding: 8px; } .copy-popup-wrapper > .copy-popup-icon { position: relative; top: 3px; } .copy-popup-wrapper.popup-to-left { /* since it is in position absolute we can just move it to the left to make it always appear on the left side of the icon */ left: -15em; } .copy-popup-wrapper.active-popup { display: flex !important; } .copy-popup-wrapper:hover { font-weight: normal; } .copy-popup-wrapper > span:last-child { padding-right: 14px; } .symbol .top-right-position { /* it is important for a parent to have a position: relative */ position: absolute; top: 8px; right: 8px; } .sideMenuPart > .overview { display: flex; align-items: center; position: relative; user-select: none; /* there's a weird bug with text selection */ padding: 8px 0; } .sideMenuPart a { display: block; align-items: center; color: var(--average-color); overflow: hidden; } .sideMenuPart a:hover { text-decoration: none; color: var(--average-color); } .sideMenuPart > .overview:before { box-sizing: border-box; content: ''; top: 0; width: 280px; right: 0; bottom: 0; position: absolute; z-index: -1; } .overview:hover:before { background-color: rgba(39, 40, 44, 0.05); } #nav-submenu { padding-left: 24px; } .sideMenuPart { padding-left: 12px; box-sizing: border-box; } .sideMenuPart.hidden > .overview .navButtonContent::before { transform: rotate(0deg); } .sideMenuPart > .overview .navButtonContent::before { content: url("../images/arrow_down.svg"); display: flex; flex-direction: row; align-items: center; justify-content: center; transform: rotate(90deg); width: 12px; height: 12px; } .sideMenuPart[data-active] > .overview .navButtonContent::before { content: url("../images/arrow_down_white.svg");; } .sideMenuPart.hidden > .navButton .navButtonContent::after { content: '\02192'; } .sideMenuPart.hidden > .sideMenuPart { height: 0; visibility: hidden; } .filtered > a, .filtered > .navButton { display: none; } body, table { font-family: 'Inter', "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif; background: var(--background-color); font-style: normal; font-weight: normal; font-size: var(--default-font-size); line-height: 24px; margin: 0; } table { width: 100%; border-collapse: collapse; background-color: #ffffff; padding: 5px; } tbody > tr { min-height: 56px; } td:first-child { width: 20vw; } .keyword { color: black; font-family: var(--default-monospace-font-family); font-size: 12px; } .identifier { color: darkblue; font-size: 12px; font-family: var(--default-monospace-font-family); } .brief { white-space: pre-wrap; overflow: hidden; } h1, h2, h3, h4, h5, h6 { color: #222; font-weight: bold; } p, ul, ol, table, pre, dl { margin: 0; } h1 { font-weight: bold; font-size: 40px; line-height: 48px; letter-spacing: -1px; } h1.cover { font-size: 60px; line-height: 64px; letter-spacing: -1.5px; margin-bottom: 0; padding-bottom: 32px; display: block; } h2 { color: #393939; font-size: 31px; line-height: 40px; letter-spacing: -0.5px; } h3 { font-size: 20px; line-height: 28px; letter-spacing: -0.2px; } h4 { margin: 0; } h3, h4, h5, h6 { color: #494949; } .UnderCoverText { font-size: 16px; line-height: 28px; } .UnderCoverText code { font-size: inherit; } .UnderCoverText table { margin: 8px 0 8px 0; word-break: break-word; } a { text-decoration: none; } #main a:not([data-name]) { padding-bottom: 2px; border-bottom: 1px solid var(--border-color); cursor: pointer; text-decoration: none; color: inherit; font-size: inherit; line-height: inherit; transition: color .1s, border-color .1s; } #main a:hover { border-bottom-color: unset; color: inherit } a small { font-size: 11px; color: #555; margin-top: -0.6em; display: block; } .wrapper { width: 860px; margin: 0 auto; } blockquote { border-left: 1px solid #e5e5e5; margin: 0; padding: 0 0 0 20px; font-style: italic; } code, pre { color: #333; font-size: var(--default-font-size); } pre { display: block; overflow-x: auto; } th, td { text-align: left; vertical-align: top; padding: 12px 10px 11px; } dt { color: #444; font-weight: 700; } th { color: #444; } p.paragraph img { display: block; } img { max-width: 100%; } strong { color: #222; font-weight: 700; } small { font-size: 11px; } .platform-tag { display: flex; flex-direction: row; padding: 4px 8px; height: 24px; border-radius: 100px; box-sizing: border-box; border: 1px solid transparent; margin: 2px; font-family: Inter, Arial, sans-serif; font-size: 12px; font-weight: 400; font-style: normal; font-stretch: normal; line-height: normal; letter-spacing: normal; text-align: center; outline: none; color: #fff } .platform-tags { display: flex; flex-wrap: wrap; padding-bottom: 8px; } .platform-tags > .platform-tag { align-self: center; } .platform-tags > .platform-tag:first-of-type { margin-left: auto; } .platform-tag.jvm-like { background-color: #4DBB5F; color: white; } .platform-tag.js-like { background-color: #FED236; color: white; } .platform-tag.native-like { background-color: #CD74F6; color: white; } .platform-tag.common-like { background-color: #A6AFBA; color: white; } .filter-section { display: flex; flex-direction: row; align-self: flex-end; min-height: 30px; z-index: 0; flex-wrap: wrap; } .platform-selector:hover { border: 1px solid #A6AFBA !important; } [data-filterable-current=''] { display: none !important; } .platform-selector:not([data-active]) { border: 1px solid #DADFE6; background-color: transparent; color: var(--average-color); } .navigation-wrapper .platform-selector:not([data-active]) { color: #FFFFFF; } td.content { padding-left: 24px; padding-top: 16px; display: flex; flex-direction: column; } .main-subrow { display: flex; flex-direction: row; padding: 0; flex-wrap: wrap; } .main-subrow > div > span { display: flex; position: relative; } .main-subrow:hover .anchor-icon { opacity: 1; transition: 0.2s; } .main-subrow .anchor-icon { padding: 0 8px; opacity: 0; transition: 0.2s 0.5s; } .main-subrow .anchor-icon::before { content: url("../images/anchor-copy-button.svg"); } .main-subrow .anchor-icon:hover { cursor: pointer; } .main-subrow .anchor-icon:hover > svg path { fill: var(--hover-link-color); } .main-subrow .anchor-wrapper { position: relative; width: 16px; height: 16px; } .inline-flex { display: inline-flex; } .platform-hinted { flex: auto; display: block; margin-bottom: 5px; } .platform-hinted > .platform-bookmarks-row > .platform-bookmark { min-width: 64px; border: 2px solid var(--background-color); background: inherit; outline: none; flex: none; order: 5; align-self: flex-start; } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.jvm-like { border-bottom: 2px solid rgba(77, 187, 95, 0.3); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.js-like { border-bottom: 2px solid rgba(254, 175, 54, 0.3); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.native-like { border-bottom: 2px solid rgba(105, 118, 249, 0.3); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.common-like { border-bottom: 2px solid rgba(161, 170, 180, 0.3); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.jvm-like[data-active=''], .platform-hinted > .platform-bookmarks-row > .platform-bookmark.jvm-like:hover { border: 2px solid var(--background-color); border-bottom: 2px solid #4DBB5F; background: var(--background-color); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.js-like[data-active=''], .platform-hinted > .platform-bookmarks-row > .platform-bookmark.js-like:hover { border: 2px solid var(--background-color); border-bottom: 2px solid #FED236; background: var(--background-color); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.native-like[data-active=''], .platform-hinted > .platform-bookmarks-row > .platform-bookmark.native-like:hover { border: 2px solid var(--background-color); border-bottom: 2px solid #CD74F6; background: var(--background-color); } .platform-hinted > .platform-bookmarks-row > .platform-bookmark.common-like[data-active=''], .platform-hinted > .platform-bookmarks-row > .platform-bookmark.common-like:hover { border: 2px solid var(--background-color); border-bottom: 2px solid #A6AFBA; background: var(--background-color); } .platform-hinted > .content:not([data-active]), .tabs-section-body > *:not([data-active]) { display: none; } /*Work around an issue: https://github.com/JetBrains/kotlin-playground/issues/91*/ .platform-hinted[data-togglable="Samples"] > .content:not([data-active]), .tabs-section-body > *[data-togglable="Samples"]:not([data-active]) { display: block !important; visibility: hidden; height: 0; position: fixed; top: 0; } .with-platform-tags { display: flex; } .with-platform-tags ~ .main-subrow { padding-top: 8px; } .cover .with-platform-tabs { background-color: white; font-size: var(--default-font-size); } .cover > .with-platform-tabs > .content { background-color: var(--background-color); padding: 8px 16px; border: 1px solid rgba(39, 40, 44, 0.20); } .cover > .block { padding-top: 48px; padding-bottom: 24px; font-size: 18px; line-height: 28px; } .cover > .block:empty { padding-bottom: 0; } .table-row .with-platform-tabs .sourceset-depenent-content .brief { padding: 8px; background-color: var(--background-color); } .sideMenuPart[data-active] > .overview:before { background: var(--color-dark); } .sideMenuPart[data-active] > .overview > a { color: var(--default-white); } .table { display: flex; flex-direction: column; } .table-row { display: flex; flex-direction: column; border-bottom: 1px solid var(--border-color); padding: 11px 0 12px 0; } .table-row:last-of-type { border-bottom: none; } .table-row .brief-comment { color: var(--average-color); } .platform-dependent-row { display: grid; padding-top: 8px; } .title-row { display: grid; grid-template-columns: auto auto 7em; width: 100%; } .keyValue { display: grid; } @media print, screen and (min-width: 960px) { .keyValue { grid-template-columns: 20% 80%; } .title-row { grid-template-columns: 20% auto 7em; } } @media print, screen and (max-width: 960px) { div.wrapper { width: auto; margin: 0; } header, section, footer { float: none; position: static; width: auto; } header { padding-right: 320px; } section { border: 1px solid #e5e5e5; border-width: 1px 0; padding: 20px 0; margin: 0 0 20px; } header a small { display: inline; } header ul { position: absolute; right: 50px; top: 52px; } } @media print, screen and (max-width: 720px) { body { word-wrap: break-word; } header { padding: 0; } header ul, header p.view { position: static; } pre, code { word-wrap: normal; } } @media print, screen and (max-width: 480px) { header ul { display: none; } } @media print { body { padding: 0.4in; font-size: 12pt; color: #444; } } .footer { clear: both; display: flex; align-items: center; position: relative; min-height: var(--footer-height); font-size: 12px; line-height: 16px; letter-spacing: 0.2px; color: var(--average-color); margin-top: auto; background-color: var(--footer-background); } .footer span.go-to-top-icon { border-radius: 2em; padding: 11px 10px !important; background-color: white; } .footer span.go-to-top-icon > a::before { content: url("../images/go-to-top-icon.svg"); } .footer > span:first-child { margin-left: var(--horizontal-spacing-for-content); padding-left: 0; } .footer > span:last-child { margin-right: var(--horizontal-spacing-for-content); padding-right: 0; } .footer > span { padding: 0 16px; } .footer a { color: var(--breadcrumb-font-color); } .footer .padded-icon { padding-left: 0.5em; } .footer .padded-icon::before { content: url("../images/footer-go-to-link.svg"); } .pull-right { float: right; margin-left: auto } div.runnablesample { height: fit-content; } .anchor-highlight { border: 1px solid var(--hover-link-color) !important; box-shadow: 0 0 0 0.2em #c8e1ff; margin-top: 0.2em; margin-bottom: 0.2em; } .w-100 { width: 100%; } .no-gutters { margin: 0; padding: 0; } .d-flex { display: flex; } @media screen and (max-width: 1119px) { h1.cover { font-size: 48px; line-height: 48px; padding-bottom: 8px; } } @media screen and (max-width: 759px) { #main { max-width: 100%; } #leftColumn { position: fixed; margin-left: -280px; transition: margin .2s ease-out; z-index: 4; background: white; height: 100%; } #leftColumn.open { margin-left: 0; } #leftColumn.open ~ #main #searchBar { display: none; } #leftToggler { z-index: 5; font-size: 20px; transition: margin .2s ease-out; margin-right: 16px; color: var(--background-color); } #leftToggler .icon-toggler:hover { cursor: pointer; } #leftColumn.open ~ #main #leftToggler { margin-left: 280px; } .icon-toggler::before { content: "\2630"; } #leftColumn.open ~ #main .icon-toggler::before { content: "\2630"; padding-right: 0.5em; margin-left: -0.5em; } .main-content > * { margin-left: var(--mobile-horizontal-spacing-for-content); margin-right: var(--mobile-horizontal-spacing-for-content); } .navigation-wrapper { padding-left: var(--mobile-horizontal-spacing-for-content); padding-right: var(--mobile-horizontal-spacing-for-content); } #sideMenu { padding-bottom: 16px; overflow: auto; } h1.cover { font-size: 32px; line-height: 32px; } }