* { margin:0; padding:0; }
html { }
body {
background-color: #f4f4f4;
color: #414141;
font: 16px/22px 'Inter UI', system-ui, sans-serif;
letter-spacing: -0.1px;
font-weight: 400;
padding-bottom: 30px;
font-kerning: normal;
-moz-font-feature-settings: "kern" 1;
-webkit-font-feature-settings: "kern" 1;
font-feature-settings: "kern" 1;
}
a {
color: inherit;
text-decoration: underline;
word-break: break-word;
word-wrap: break-word;
}
a.fat {
font-weight:500;
color: #333;
}
a:hover {
color: rgb(48, 112, 232);
}
a.plain, a.fat {
/* !important needed for qualification over @media further down */
background: none !important;
text-shadow: none !important;
text-decoration: none;
cursor: pointer;
}
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;
}
h1 {
color: #222;
font-size: 55px;
letter-spacing: -2.1px;
line-height: 50px;
text-indent: -2.5px;
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;
font-weight:400;
margin:0;
margin-top:-1.9em;
}
h2.back a:hover {
color: black;
margin-left:-1.6em;
}
h2.back a:hover::before {
content: "<- ";
}
h3 {
font-size: inherit;
}
h1 > a, h2 > a, h3 > a {
color: inherit;
text-decoration: none;
text-shadow: none;
background: none !important;
}
.row {
padding: 50px;
/*background: salmon;*/
display: flex;
justify-content: center;
/*background: white;*/
}
.row > * {
width:100%;
max-width: 888px;
flex: 1 0 100%;
/*background: white;*/
}
.row-divider {
margin:0 auto;
max-width: 888px;
height: 1px;
border-bottom: 1px dashed rgba(0,0,0,0.09);
}
/* small screens (up to iPhone 6) */
@media only screen and (max-device-width: 736px) {
body {
font-size: 14px;
line-height: 20px;
}
.row {
padding-left: 20px;
padding-right: 20px;
}
}
.row.white {
background: white;
}
.row.dark {
background: #2b2b2b;
color: #99999b;
}
.row.dark a:hover {
color: rgb(164, 188, 255);
}
.row.dark h2, .row.dark h2 > a {
color: #ccc;
background: none;
}
.row.color1 {
background: #C0CDE2;
color: #3B414A;
}
/*
Medium.com-style link underline for high-density displays.
Currently only enabled on Mac as the lines don't render correctly on
Windows (even in Chrome) for some reason.
*/
@media (-webkit-min-device-pixel-ratio: 1.5) {
a {
text-decoration: none;
background-image:
linear-gradient(to bottom,
rgba(0,0,0,.6) 50%,
rgba(0,0,0,0) 50%);
background-repeat: repeat-x;
background-size: 2px .1em;
background-position: 0 1.15em;
text-shadow:
/* creates "openings" for descenders in the underline */
-1px -1px 0 #f4f4f4,
1px -1px 0 #f4f4f4,
-1px 1px 0 #f4f4f4,
1px 1px 0 #f4f4f4;
}
body.mac_or_ios a {
/* line height calculated differently on mac c/t windows */
background-position: 0 1.045em;
}
a:hover {
background-image:
linear-gradient(to bottom,
rgba(48, 112, 232, 1) 50%,
rgba(48, 112, 232, 0) 50%);
}
.row.white a {
text-shadow:
-1px -1px 0 white,
1px -1px 0 white,
-1px 1px 0 white,
1px 1px 0 white;
}
.row.dark a {
background-image:
linear-gradient(to bottom,
rgba(255,255,255,.3) 50%,
rgba(255,255,255,0) 50%);
text-shadow:
-1px -1px 0 #2b2b2b,
1px -1px 0 #2b2b2b,
-1px 1px 0 #2b2b2b,
1px 1px 0 #2b2b2b;
}
.row.dark a:hover {
background-image:
linear-gradient(to bottom,
rgba(164, 188, 255, 1) 50%,
rgba(164, 188, 255, 0) 50%);
}
}
::selection {
background: rgb(48, 112, 232);
color: white;
text-shadow: none;
}
::-moz-selection {
background: rgb(48, 112, 232);
color: white;
text-shadow: none;
}
.row.dark ::selection {
background: rgb(218, 228, 255);
color: black;
}
.row.dark ::-moz-selection {
background: rgb(164, 188, 255);
color: black;
}
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 > a {
display: inline;
}
ul.faq > li:target {
background: #fafa88;
}
li.q {
font-weight: 500;
margin-top:1.5em;
}
ul > li.q:first-child, ul > li.q:not([id]) {
margin-top:0;
}
li.q:before {
content: "Q "; /* contains NO-BREAK SPACE */
opacity: 0.6;
}
li.q:after {
content: "";
}
li.a:before {
content: "A "; /* contains NO-BREAK SPACE */
opacity: 0.6;
}
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;
}
}