* { margin:0; padding:0; } html { } body { background-color: #f4f4f4; color: #414141; font: 15px/22px 'Inter UI', system-ui, sans-serif; font-size: 15px; line-height:1.4; /*letter-spacing: 0.009em;*/ font-weight: 400; padding-bottom: 30px; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; -webkit-overflow-scrolling: touch; scroll-behavior: smooth; font-kerning: normal; -moz-font-feature-settings:"kern" 1, "liga" 1; -ms-font-feature-settings:"kern" 1, "liga" 1; -o-font-feature-settings:"kern" 1, "liga" 1; -webkit-font-feature-settings:"kern" 1, "liga" 1; font-feature-settings:"kern" 1, "liga" 1; } :target:before { content:""; display: block; height: 20px; /* fixed header height*/ margin: -20px 0 0; /* negative fixed header height */ } a { text-decoration: underline rgba(0, 0, 0, 0.3); color: black; word-break: break-word; word-wrap: break-word; } a.fat { font-weight:500; color: #333; } a:hover { color: rgba(3, 102, 214, 1); text-decoration: underline rgba(3, 102, 214, 0.6); } a.plain, a.fat { background: none; text-shadow: none; text-decoration: none; cursor: pointer; } a[href^="#"]:hover { text-decoration-style: dashed; } p { margin: 20px 0; } code, pre, q { font-family: "SFMono-Regular", Menlo, Consolas, Inconsolata, monospace; font-size:0.96em; } code { display: block; border-radius:1px; padding: 0.5em 0; overflow: auto; } pre, q { display: inline; white-space: pre-wrap; } q { display: inline; } q:before { content: ""; } q:after { content: ""; } kbd { font-feature-settings: 'kern' 1, 'case' 1; border: 1px solid rgba(0,0,0,0.18); border-radius: 3px; padding:0.1em 0.2em; margin:0 0.1em; } dem { /* de-emphasize */ font-weight: 400; opacity: 0.7; } num { /* number */ font-feature-settings: 'calt' 1, 'ss01' 1; white-space: pre; } h1, h2, h3 { font-weight: 500; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } h1 { color: #222; font-size: 55px; letter-spacing: -0.03em; line-height: 1.1em; text-indent: -2px; margin-bottom: 30px; margin-top: 10px; font-weight: 700; } h2 { font-size: 24px; letter-spacing: -0.4px; line-height: 30px; margin-bottom: 25px; margin-top: 10px; } h2.back { color:rgba(0,0,0,0.2); font-size: inherit; letter-spacing: inherit; font-weight:400; margin:0; margin-top:-1.9em; } h2.back a:hover { color: black; margin-left:-1.3em; } h2.back a:hover::before { content: "<- "; } h3 { font-size: inherit; } h1 > a, h2 > a, h3 > a { color: inherit; text-decoration: none !important; text-shadow: none; background: none !important; } .row { padding: 50px; display: flex; justify-content: center; } .row > * { width:100%; max-width: 888px; flex: 1 0 100%; } .row-divider { margin:0 auto; max-width: 888px; height: 1px; border-bottom: 1px dashed rgba(0,0,0,0.09); } .row.menu { padding: 0; border-bottom:1px solid rgba(0,0,0,0.1); } .row.menu ul { width: auto; max-width: 888px; flex: 1 1 auto; list-style: none; padding: 0; margin: 0 50px; display: flex; flex-wrap: wrap; white-space: nowrap; } .row.menu ul li { margin-right: 30px; margin-bottom: -1px; } .row.menu ul li > a { color: inherit; opacity: 0.6; text-decoration:none; display: inline-block; padding: 15px 0 13px 0; transition: 300ms opacity cubic-bezier(0.25, 0.47, 0.44, 0.93); border-bottom: 3px solid transparent; } .row.menu ul li > a:hover { color: black; border-bottom-color: black; opacity: 1; } /* narrow windows */ @media only screen and (max-width: 500px) { .row.menu ul { justify-content: space-between; } .row.menu ul li { margin-right: 15px; } .row.menu ul li:last-child { margin-right: 0; } } /* small devices (<= iPhone 6+) */ @media only screen and (max-device-width: 414px) { body { font-size: 14px; line-height: 20px; } .row { padding-left: 20px; padding-right: 20px; } .row.menu ul { margin-left: 20px; margin-right: 20px; } } /* small devices (<= iPhone 5) */ @media only screen and (max-device-width: 320px) { .row.menu { font-size:13px; } .row.menu ul { margin-left: 0; margin-right: 0; } .row.menu ul li { flex: 1 0 auto; text-align: center; border-right: 1px solid rgba(0,0,0,0.1); margin-left:0; margin-right:0; } .row.menu ul li:last-child { border-right: none; } } .row.white { background: white; } .row.dark { background: #2b2b2b; color: #99999b; } .row.dark a { text-decoration-color: rgba(255, 255, 255, 0.2); color: #aaa; } .row.dark a:hover { color: rgba(160, 190, 255, 1); text-decoration: underline rgba(164, 188, 255, 0.6); } .row.dark h2, .row.dark h2 > a { color: #ccc; background: none; } .row.color1 { background: #C0CDE2; color: #3B414A; } ul { margin-left:1.1em; } a > img { display: block; } #repertoire-image { display:block; width:100%; height:40vw; background-image: url(res/repertoire.png); background-repeat: no-repeat; background-size: cover; background-blend-mode: multiply; background-color: #f4f4f4; } /* FAQ */ ul.faq { list-style:none; display: flex; flex-direction: column; margin-left:0; } ul.faq > li { padding-right: 6px; margin-bottom: 6px; padding-left: 1.5em; text-indent: -1.5em; } ul.faq > li:target { background: #fafa88; margin-left: -1.5em; } ul.faq > li > a.anchor { visibility: hidden; height:0; position:relative; } li.q { font-weight: 500; margin-top:1.5em; } ul > li.q:first-child, ul > li.q:not([id]) { margin-top:0; } tablex { display: flex; } tablex > t { display: table; } tablex > t > h { display: table-row; opacity:0.4; } tablex > t > h > * { padding-bottom:1em; } tablex > t > h to { visibility: hidden; } tablex > t > r { text-decoration: none; display: table-row; } tablex in, tablex to, tablex out { display: table-cell; width: 5%; white-space: pre; padding-bottom:0.5em; } /*tablex to { width:0; }*/ tablex to::after { font-feature-settings: 'calt' 1, 'case' 1; content: " → "; color: rgba(0,0,0,0.2); } tablex in, tablex out { color: rgba(0,0,0,0.8); } tablex in { font-feature-settings: 'calt' 0; } tablex out { font-feature-settings: 'calt' 1; } tablex out.zero { font-feature-settings: 'calt' 1, 'zero' 1; } tablex out.tnum { font-feature-settings: 'calt' 1, 'tnum' 1; } tablex out.case { font-feature-settings: 'calt' 1, 'case' 1; } tablex out.frac { font-feature-settings: 'calt' 1, 'frac' 1; } tablex out.ss01 { font-feature-settings: 'calt' 1, 'ss01' 1; } tablex em { font-style: inherit; background: #FBE9A3; color: rgba(0,0,0,1); } boxes { display: flex; flex-wrap: wrap; justify-content: stretch; margin-right:-1em; } box { overflow: auto; max-width:100%; display: flex; flex-direction: column; background: white; padding:2em; border-radius: 3px; margin-right:1em; margin-bottom:1em; flex: 1 1 10%; /*width:220px;*/ } body.safari box { /* Fix for broken flex wrap in safari */ flex-basis: 40%; } box:first-child { margin-left:0; } box h3 { margin-bottom:0.8em; } .glyph-repertoire { position: relative; background: white; margin-bottom:0; border-top-left-radius:3px; border-top-right-radius:3px; padding-top:3px; } .glyph-repertoire-link { margin-top:0; background: white; border-bottom-left-radius:3px; border-bottom-right-radius:3px; } .glyph-repertoire-link a { display: block; padding: 2em; text-align: center; } .glyph-repertoire .fade { position: absolute; display: block; left:0; bottom:0; right:0; height:50px; pointer-events: none; background-image: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%); background-repeat: repeat-x; background-size: 2px 50px; background-position: 0 0; } .glyph-repertoire a { display: block; font-feature-settings: 'case' 1; } .glyph-repertoire iframe { pointer-events: none; /*width: 100%; height: 100px;*/ /*height: 0.5vh;*/ height: 330px; width: 1px; min-width: 100%; *width: 100%; } .carousel, .carousel * { user-select: none; cursor: default; } .carousel .header { display: flex; justify-content: space-between; align-items: center; line-height: 40px; height: 40px; /*background:#eee;*/ } .carousel .header h2 { margin: 0 0 1px 0; } .carousel .dots { display: flex; align-items: stretch; /*background:salmon;*/ height: 40px; } .carousel .dots > .dot { width: 14px; margin: 0; display: flex; align-items: center; } .carousel .dot > .graphic { box-sizing: border-box; border-radius: 100%; width: 10px; height: 10px; border: 1px solid #ccc; } .carousel .dots > .dot:hover > .graphic { border-color:#111; } .carousel .dots > .dot.active > .graphic { background: #222; border: none; } .carousel .preload { visibility: hidden; pointer-events: none; position: fixed; } .carousel .items { margin-bottom: 0; overflow-x: scroll; overflow-y: hidden; -webkit-overflow-scrolling: touch; height:780px; /*width: 100vw;*/ display: flex; flex-direction: row; align-items: center; } .carousel .items > * { flex: 1 0 auto; margin-right: 20vw; width: 80vw; max-width: 888px; cursor: e-resize; transition: all 200ms ease-out; } .carousel .items > .loading { opacity: 0.6; -webkit-filter: url('#blur'); filter: url('#blur'); -webkit-filter: blur(20px); filter: blur(20px); } @media only screen and (max-device-width: 780px) and (orientation: portrait) { .carousel .items { height: auto !important; max-height: 90vw; } .carousel .items img { max-height: 90vw; } } @media only screen and (max-device-width: 780px) and (orientation: landscape) { .carousel .items { height: auto !important; width: 90vh; margin: 0 auto; } .carousel .items > * { width: 90vh; max-height: 90vh; } }