/* Colors */
/* even rows in list or tables, subtle shade of $c-bg-high */
/* Primary: blue */
/* text over primary background */
/* Secondary: green */
/* text over secondary background */
/* Accent: orange */
/* text over accent background */
/* Brag: gold */
/* text over brag background */
/* Error: red */
/* text over brag background */
/* Good: green */
/* Warn: orange */
/* Bad: red */
/* Fancy: pink */
/* text over brag background */
/* Borders */
/* Shadows */
/* Custom */
/* even rows in list or tables, subtle shade of $c-bg-high */
/* Primary: blue */
/* Secondary: green */
/* Brag: gold */
/* Fancy: pink */
/* Good: green */
/* Warn: orange */
/* Bad: red */
/* Common imports for all embedded widgets */
/* Widths */
/* Heights */
/* Orientations */
/* Capabilities */
/* Aliases */
/* Uniboard: keep the same page layout accross pages */
/* when the width is appropriate for col1, but landscape prevents it */
/* atm only chrome supports min-content, max-content */
html {
  font-family: 'Noto Sans', Sans-Serif;
}

.ninja-title {
  font-family: 'Noto Sans';
}

h1,
h2,
h3,
h4, .mini-game .rating, .mini-game__clock {
  font-family: 'Roboto';
}

/* text printed directly on the page background deserves special treatment (transp theme) */
#trainer group.radio input:checked + label {
  background: #0456bc;
}

.mini-game {
  white-space: nowrap;
  overflow: hidden;
}

.main-board, .mini-board, .mini-game .cg-wrap {
  position: relative;
  display: block;
  height: 0;
  padding-bottom: 100%;
  width: 100%;
}

.is::before,
[data-icon]::before,
.is-after::after {
  font-size: 1.2em;
  vertical-align: middle;
  font-family: 'lichess';
  font-style: normal;
  font-weight: normal;
  text-transform: none;
  speak: none;
  content: attr(data-icon);
  opacity: 0.9;
}

cg-board, .main-board .cg-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
}

.mini-game__player {
  /* extends %flex-center */
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: space-between;
}

cg-board {
  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}

html {
  box-sizing: border-box;
  min-height: 100%;
}

*, *::before, *::after {
  box-sizing: inherit;
  margin: 0;
  padding: 0;
}

body {
  background-color: #161512;
  background-image: none;
  background-size: auto;
  color: #bababa;
  overflow-x: hidden;
}

body.fixed-scroll {
  /* prevents scroll bar flicker when dragging a piece out */
  overflow-y: scroll;
}

a {
  color: #3692e7;
  text-decoration: none;
}

a:hover, a:active, a:focus {
  color: #57aeff;
}

p {
  margin-bottom: 1em;
}

em, i {
  font-style: normal;
}

li {
  list-style: none;
}

time {
  font-size: 90%;
  opacity: 0.9;
  /* don't use c-color-dim, it overrides too hard */
}

hr {
  margin: 1.5rem 0;
  border: 0;
  height: 1px;
  background: #404040;
}

small {
  font-size: .9em;
}

table, tbody, tfoot, thead, tr, th, td {
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: middle;
  text-align: inherit;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

@font-face {
  font-family: "lichess";
  src: url(../font/lichess.woff2) format("woff2"), url(../font/lichess.woff) format("woff");
  font-display: block;
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Noto Chess';
  src: url(../font/lichess.chess.woff2) format("woff2"), url(../font/lichess.chess.woff) format("woff");
}

/* cyrillic-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6DRAW_0.woff2) format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr4TRAW_0.woff2) format("woff2");
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr5DRAW_0.woff2) format("woff2");
  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;
}

/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6TRAW_0.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr5jRAW_0.woff2) format("woff2");
  unicode-range: U+0370-03FF;
}

/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6jRAW_0.woff2) format("woff2");
  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6zRAW_0.woff2) format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans"), local("NotoSans"), url(../font/noto-sans-latin.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* cyrillic-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVadyB1Wk.woff2) format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVYNyB1Wk.woff2) format("woff2");
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* devanagari */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVZdyB1Wk.woff2) format("woff2");
  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;
}

/* greek-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVaNyB1Wk.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVZ9yB1Wk.woff2) format("woff2");
  unicode-range: U+0370-03FF;
}

/* vietnamese */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVa9yB1Wk.woff2) format("woff2");
  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVatyB1Wk.woff2) format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Noto Sans';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans Bold"), local("NotoSans-Bold"), url(../font/noto-sans-bold-latin.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* cyrillic-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCRc4EsA.woff2) format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fABc4EsA.woff2) format("woff2");
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* greek-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCBc4EsA.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fBxc4EsA.woff2) format("woff2");
  unicode-range: U+0370-03FF;
}

/* vietnamese */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCxc4EsA.woff2) format("woff2");
  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fChc4EsA.woff2) format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local("Roboto Light"), local("Roboto-Light"), url(../font/roboto-light-latin.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html {
  font-size: 12px;
}

@media (min-width: 320px) {
  html {
    font-size: calc(12px + 2 * ((100vw - 320px) / 880));
  }
}

@media (min-width: 1200px) {
  html {
    font-size: 14px;
  }
}

h1,
h2,
h3,
h4 {
  font-weight: normal;
  font-size: 1em;
}

h1 {
  margin-bottom: 5vh;
}

h1 {
  font-size: 20px;
}

@media (min-width: 320px) {
  h1 {
    font-size: calc(20px + 20 * ((100vw - 320px) / 880));
  }
}

@media (min-width: 1200px) {
  h1 {
    font-size: 40px;
  }
}

h1 a {
  color: #2e7cc5;
}

h1 a:hover {
  color: #3692e7;
}

h2 {
  font-size: 16px;
}

@media (min-width: 320px) {
  h2 {
    font-size: calc(16px + 14 * ((100vw - 320px) / 880));
  }
}

@media (min-width: 1200px) {
  h2 {
    font-size: 30px;
  }
}

.ninja-title {
  font-size: 1em;
}

.is.text::before,
.text[data-icon]::before {
  margin-right: .4em;
}

.user-link.online .line,
.is-green::before {
  color: #bd111f;
}

.is-red::before {
  color: #cc3333;
}

.is-gold::before {
  color: #bf811d;
}

.blue .is2d cg-board {
  background-image: url(../images/board/svg/blue.svg);
}

.blue2 .is2d cg-board {
  background-image: url(../images/board/blue2.jpg);
}

.blue-marble .is2d cg-board {
  background-image: url(../images/board/blue-marble.jpg);
}

.wood2 .is2d cg-board {
  background-image: url(../images/board/wood2.jpg);
}

.wood3 .is2d cg-board {
  background-image: url(../images/board/wood3.jpg);
}

.wood4 .is2d cg-board {
  background-image: url(../images/board/wood4-1024.jpg);
}

.blue3 .is2d cg-board {
  background-image: url(../images/board/blue3.jpg);
}

.marble .is2d cg-board {
  background-image: url(../images/board/marble.jpg);
}

.brown .is2d cg-board {
  background-image: url(../images/board/svg/brown.svg);
}

.green .is2d cg-board {
  background-image: url(../images/board/svg/green.svg);
}

.green-plastic .is2d cg-board {
  background-image: url(../images/board/green-plastic.png);
}

.olive .is2d cg-board {
  background-image: url(../images/board/olive.jpg);
}

.purple .is2d cg-board {
  background-image: url(../images/board/svg/purple.svg);
}

.purple-diag .is2d cg-board {
  background-image: url(../images/board/purple-diag.png);
}

.grey .is2d cg-board {
  background-image: url(../images/board/grey.jpg);
}

.wood .is2d cg-board {
  background-image: url(../images/board/wood-1024.jpg);
}

.canvas .is2d cg-board {
  background-image: url(../images/board/canvas2-1024.jpg);
}

.leather .is2d cg-board {
  background-image: url(../images/board/leather-1024.jpg);
}

.metal .is2d cg-board {
  background-image: url(../images/board/metal-1024.jpg);
}

.maple .is2d cg-board {
  background-image: url(../images/board/maple.jpg);
}

.maple2 .is2d cg-board {
  background-image: url(../images/board/maple2.jpg);
}

.newspaper .is2d cg-board {
  background-image: url(../images/board/newspaper.png);
}

.pink .is2d cg-board {
  background-image: url(../images/board/pink-pyramid.png);
}

.ic .is2d cg-board {
  background-image: url(../images/board/svg/ic.svg);
}

cg-board {
  top: 0;
  left: 0;
  user-select: none;
  line-height: 0;
  background-size: cover;
}

.manipulable cg-board {
  cursor: pointer;
}

square {
  position: absolute;
  width: 12.5%;
  height: 12.5%;
  pointer-events: none;
}

square.move-dest {
  background: radial-gradient(rgba(20, 85, 30, 0.5) 19%, rgba(0, 0, 0, 0) 20%);
  pointer-events: auto;
}

square.premove-dest {
  background: radial-gradient(rgba(20, 30, 85, 0.5) 19%, rgba(0, 0, 0, 0) 20%);
  pointer-events: auto;
}

square.oc.move-dest {
  background: radial-gradient(transparent 0%, transparent 80%, rgba(20, 85, 0, 0.3) 80%);
}

square.oc.premove-dest {
  background: radial-gradient(transparent 0%, transparent 80%, rgba(20, 30, 85, 0.2) 80%);
}

body.green square.last-move,
body.green-plastic square.last-move,
body.marble square.last-move {
  background-color: rgba(0, 155, 199, 0.41);
}

square.last-move {
  will-change: transform;
  background-color: rgba(155, 199, 0, 0.41);
}

square.check {
  background: radial-gradient(ellipse at center, red 0%, #e70000 25%, rgba(169, 0, 0, 0) 89%, rgba(158, 0, 0, 0) 100%);
}

square.selected {
  background-color: rgba(20, 85, 30, 0.5);
}

square.current-premove {
  background-color: rgba(20, 30, 85, 0.5) !important;
}

square.move-dest:hover {
  background: rgba(20, 85, 30, 0.3);
}

square.premove-dest:hover {
  background: rgba(20, 30, 85, 0.2);
}

square.bh1 piece {
  opacity: 0.98;
}

piece {
  position: absolute;
  top: 0;
  left: 0;
  width: 12.5%;
  height: 12.5%;
  background-size: cover;
  z-index: 2;
  will-change: transform;
  pointer-events: none;
}

piece.dragging {
  cursor: move;
  z-index: 204;
}

piece.anim {
  z-index: 3;
}

piece.fading {
  z-index: 1;
  opacity: 0.5;
}

piece.ghost {
  opacity: 0.3;
}

cg-helper {
  position: absolute;
  width: 12.5%;
  padding-bottom: 12.5%;
  display: table;
  /* hack: round to full pixel size in chrome */
  bottom: 0;
}

cg-container {
  position: absolute;
  width: 800%;
  height: 800%;
  display: block;
  bottom: 0;
}

.cg-wrap svg {
  overflow: hidden;
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
  opacity: 0.6;
}

.cg-wrap svg image {
  opacity: 0.5;
}

.main-board__preload {
  position: absolute;
}

.mini-game {
  display: block;
}

.mini-game, .mini-game:hover {
  color: #bababa;
}

.mini-game__player {
  padding: 3px 2px 0 2px;
}

.mini-game__player:first-child {
  padding: 0 2px 2px 2px;
}

.mini-game__user {
  overflow: hidden;
}

.mini-game .rating {
  font-size: .9em;
  margin-left: 1ch;
}

.mini-game__clock {
  padding: 0 1ch;
}

.mini-game__clock.clock--run {
  color: #bd111f;
  font-weight: bold;
}

.mini-game__result {
  font-weight: bold;
  margin-right: 1ch;
}

body {
  background: none;
  overflow: hidden;
}

.embedded {
  display: block;
  background: #161512;
  padding: .3em;
  color: #bababa !important;
}

.embedded cg-board {
  box-shadow: none;
}

.embedded .text {
  display: block;
  text-align: center;
  margin: .3em 0;
}

/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"site/css/build/tv.embed.dark.css","sources":["site/css/build/tv.embed.dark.scss","common/css/theme/_dark.scss","common/css/theme/_default.scss","common/css/abstract/_functions.scss","site/css/build/_tv.embed.scss","common/css/_embed.scss","../node_modules/breakpoint-sass/stylesheets/_breakpoint.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_settings.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_context.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_helpers.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_parsers.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/_query.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/_single.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/single/_default.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/_double.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/double/_default-pair.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/double/_double-string.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/double/_default.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/_triple.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/triple/_default.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/_resolution.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/parsers/resolution/_resolution.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_no-query.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_respond-to.scss","../node_modules/breakpoint-sass/stylesheets/breakpoint/_legacy-settings.scss","common/css/abstract/_all.scss","common/css/abstract/_z-index.scss","common/css/abstract/_media-queries.scss","common/css/abstract/_variables.scss","common/css/abstract/_uniboard.scss","common/css/abstract/_mixins.scss","common/css/abstract/_extends.scss","common/css/abstract/_flex.scss","common/css/abstract/_box.scss","common/css/abstract/_fluid-size.scss","common/css/base/_elements.scss","common/css/base/_fonts.scss","common/css/base/_typography.scss","common/css/base/_data-icon.scss","common/css/vendor/chessground/_chessground.scss","common/css/vendor/chessground/_board-2d.scss","common/css/component/_board.scss","common/css/component/_mini-game.scss","site/css/tv/_embed.scss"],"sourcesContent":["@import \"../../../common/css/theme/dark\";\n@import \"tv.embed\";\n","@import \"default\";\n\n$theme: \"dark\";\n$theme-light: false;\n$theme-dark: true;\n\n@function c-dimmer($color, $weight: 20%) {\n  @return mix(#000, $color, $weight);\n}\n\n@function c-clearer($color, $weight: 20%) {\n  @return mix(#fff, $color, $weight);\n}\n\n$c-bg-page: hsl($c-site-hue, 10%, 8%);\n$c-bg-high: hsl($c-site-hue, 7%, 14%);\n$c-bg-low: hsl($c-site-hue, 7%, 22%);\n\n/* even rows in list or tables, subtle shade of $c-bg-high */\n$c-bg-zebra: hsl($c-site-hue, 5%, 18%);\n$c-bg-zebra2: hsl($c-site-hue, 5%, 23%);\n\n$c-body-gradient: hsl($c-site-hue, 12%, 16%);\n\n$c-font: hsl(0, 0%, 73%);\n$c-font-dim: c-light($c-font, 60%);\n$c-font-dimmer: c-light($c-font, 42%);\n$c-font-clear: c-light($c-font, 80%);\n$c-font-clearer: c-light($c-font, 89%);\n$c-shade: c-light($c-font, 30%);\n$c-font-page: $c-font-dim;\n\n/* Primary: blue */\n$c-primary: hsl(209, 79%, 56%);\n$c-primary-dim: c-dimmer($c-primary, 15%);\n$c-primary-clear: c-clearer($c-primary);\n\n/* Secondary: green */\n$c-secondary: hsl(88, 62%, 37%);\n$c-secondary-dim: c-dimmer($c-secondary);\n$c-secondary-dimmer: c-dimmer($c-secondary, 40%);\n\n/* Brag: gold */\n$c-brag: hsl(37, 74%, 43%);\n\n/* Fancy: pink */\n$c-fancy: hsl(294, 62%, 48%);\n\n/* Good: green */\n$c-good: $c-secondary;\n$c-good-over: $c-secondary-over;\n\n/* Warn: orange */\n$c-warn: $c-brag;\n$c-warn-over: $c-brag-over;\n\n/* Bad: red */\n$c-bad: $c-error;\n$c-bad-over: $c-error-over;\n\n$c-link: $c-primary;\n$c-link-dim: $c-primary-dim;\n$c-link-clear: $c-primary-clear;\n$c-link-hover: c-clearer(saturate($c-primary, 100%), 25%);\n\n$c-bg-box: $c-bg-high;\n$c-bg-box-opaque: $c-bg-box;\n$c-bg-input: c-light($c-bg-page, 13%);\n\n$c-bg-popup: $c-bg-low;\n$c-popup: $c-font-clear;\n\n$c-bg-header-dropdown: $c-bg-popup;\n$c-header-dropdown: $c-popup;\n\n$c-bot: $c-fancy;\n\n$c-page-input: $c-bg-box;\n\n$c-border: hsl(0, 0%, 25%);\n$c-border-page: hsl(0, 0%, 22%);\n$border: $border-width $border-style $c-border;\n\n$c-font-shadow: black;\n$text-shadow: none;\n\n@mixin metal-bg {\n  background: linear-gradient(to bottom, hsl($c-site-hue, 7%, 22), hsl($c-site-hue, 5%, 19) 100%);\n}\n\n@mixin metal {\n  @include metal-bg;\n}\n\n@mixin metal-hover {\n  background: linear-gradient(to bottom, hsl($c-site-hue, 7%, 25), hsl($c-site-hue, 5%, 22) 100%);\n  color: $c-font-clear;\n}\n\n@mixin page-metal {\n  @include metal;\n}\n\n@mixin page-metal-hover {\n  @include metal-hover;\n}\n\n@mixin theme-style {}\n","@import \"../abstract/functions\";\n\n/* Colors */\n\n@function c-dimmer($color, $weight: 17%) {\n  @return mix(#fff, $color, $weight);\n}\n\n@function c-clearer($color, $weight: 17%) {\n  @return mix(#000, $color, $weight);\n}\n\n$c-site-hue: 37;\n\n$c-bg-page: hsl($c-site-hue, 10%, 92%);\n\n$c-bg-page-img: none;\n$c-bg-page-bs: auto;\n\n// hsl(210, 17%, 95%)\n$c-bg-high: hsl(0, 0%, 100%);\n$c-bg-low: hsl(0, 0%, 89%);\n\n/* even rows in list or tables, subtle shade of $c-bg-high */\n$c-bg-zebra: hsl($c-site-hue, 12%, 96.5%);\n$c-bg-zebra2: hsl($c-site-hue, 12%, 92%);\n\n$c-body-gradient: hsl($c-site-hue, 12%, 84%);\n\n$c-font: hsl(0, 0%, 30%);\n$c-font-dim: c-light($c-font, 47%);\n$c-font-dimmer: c-light($c-font, 70%);\n$c-font-clear: c-light($c-font, 12%);\n$c-font-clearer: c-light($c-font, 0%);\n$c-shade: c-dimmer($c-font, 80%);\n$c-font-page: c-light($c-font, 37%);\n\n/* Primary: blue */\n$c-primary: #bd111f;\n$c-primary-dim: c-dimmer($c-primary);\n$c-primary-clear: c-clearer($c-primary);\n$c-primary-over: #fff;\n\n/* text over primary background */\n\n/* Secondary: green */\n$c-secondary: hsl(88, 62%, 37%);\n$c-secondary-dim: c-dimmer($c-secondary);\n$c-secondary-dimmer: c-dimmer($c-secondary, 40%);\n$c-secondary-over: #fff;\n\n/* text over secondary background */\n\n/* Accent: orange */\n$c-accent: #bd111f;\n$c-accent-dim: c-dimmer($c-accent);\n$c-accent-clear: c-clearer($c-accent);\n$c-accent-over: #fff;\n\n/* text over accent background */\n\n/* Brag: gold */\n$c-brag: hsl(37, 74%, 48%);\n$c-brag-over: #fff;\n\n/* text over brag background */\n\n/* Error: red */\n$c-red: hsl(0, 60%, 50%);\n$c-error: $c-red;\n$c-error-over: #fff;\n\n/* text over brag background */\n\n/* Good: green */\n$c-good: $c-secondary;\n$c-good-over: $c-secondary-over;\n\n/* Warn: orange */\n$c-warn: $c-brag;\n$c-warn-over: $c-brag-over;\n\n/* Bad: red */\n$c-bad: $c-error;\n$c-bad-over: $c-error-over;\n\n/* Fancy: pink */\n$c-fancy: hsl(294, 61%, 62%);\n$c-fancy-over: white;\n\n/* text over brag background */\n\n$c-link: $c-primary;\n$c-link-dim: $c-primary-dim;\n$c-link-clear: $c-primary-clear;\n$c-link-hover: c-clearer(saturate($c-primary, 100%), 35%);\n$c-link-over: $c-primary-over;\n\n$c-bg-box: $c-bg-high;\n$c-bg-box-opaque: $c-bg-box;\n$c-bg-input: c-light($c-bg-page, 98%);\n\n$c-border: hsl(0, 0%, 85%);\n$c-border-page: hsl(0, 0%, 80%);\n\n$c-page-mask: hsla(0, 0, 0%, 0.6);\n\n$c-bg-popup: $c-bg-high;\n$c-popup: $c-font;\n\n$c-bg-header-dropdown: $c-bg-popup;\n$c-header-dropdown: $c-popup;\n\n$c-font-shadow: white;\n$text-shadow: 0 1px 0 $c-font-shadow;\n\n$c-bot: $c-fancy;\n\n$c-page-input: $c-bg-low;\n\n/* Borders */\n\n$border-width: 1px;\n$border-style: solid;\n$border: $border-width $border-style $c-border;\n\n/* Shadows */\n\n$box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n// $box-shadow: 0 2px 2px 0 rgba(0,0,0,.157);\n\n/* Custom */\n$warning-icon-color: hsl(44, 100%, 46%);\n","@function c-light($color, $value) {\n  @return change-color($color, $lightness: $value);\n}\n\n@function img-url($path) {\n  @return url(\"#{$img-path}/#{$path}\");\n}\n","@import \"../../../common/css/embed\";\n@import \"../../../common/css/component/board\";\n@import \"../../../common/css/component/mini-game\";\n@import \"../tv/embed\";\n","/* Common imports for all embedded widgets */\n\n@import \"../../../node_modules/breakpoint-sass/stylesheets/breakpoint\";\n\n@import \"abstract/all\";\n@import \"base/elements\";\n@import \"base/fonts\";\n@import \"base/typography\";\n@import \"base/data-icon\";\n\n@include theme-style;\n\n@import \"vendor/chessground/chessground\";\n","//////////////////////////////\n// Default Variables\n//////////////////////////////\n$Breakpoint-Settings: (\n  'default media': all,\n  'default feature': min-width,\n  'default pair': width,\n\n  'force all media type': false,\n  'to ems': false,\n  'transform resolutions': true,\n\n  'no queries': false,\n  'no query fallbacks': false,\n\n  'base font size': 16px,\n\n  'legacy syntax': false\n);\n\n$breakpoint: () !default;\n\n//////////////////////////////\n// Imports\n//////////////////////////////\n@import \"breakpoint/settings\";\n@import 'breakpoint/context';\n@import 'breakpoint/helpers';\n@import 'breakpoint/parsers';\n@import 'breakpoint/no-query';\n\n@import 'breakpoint/respond-to';\n\n@import \"breakpoint/legacy-settings\";\n\n//////////////////////////////\n// Breakpoint Mixin\n//////////////////////////////\n\n@mixin breakpoint($query, $no-query: false) {\n  @include legacy-settings-warning;\n\n  // Reset contexts\n  @include private-breakpoint-reset-contexts();\n\n  $breakpoint: breakpoint($query, false);\n\n  $query-string: map-get($breakpoint, 'query');\n  $query-fallback: map-get($breakpoint, 'fallback');\n\n  $private-breakpoint-context-holder: map-get($breakpoint, 'context holder') !global;\n  $private-breakpoint-query-count: map-get($breakpoint, 'query count') !global;\n\n  // Allow for an as-needed override or usage of no query fallback.\n  @if $no-query != false {\n    $query-fallback: $no-query;\n  }\n\n  @if $query-fallback != false {\n    $context-setter: private-breakpoint-set-context('no-query', $query-fallback);\n  }\n\n  // Print Out Query String\n  @if not breakpoint-get('no queries') {\n    @media #{$query-string} {\n      @content;\n    }\n  }\n\n  @if breakpoint-get('no query fallbacks') != false or breakpoint-get('no queries') == true {\n\n    $type: type-of(breakpoint-get('no query fallbacks'));\n    $print: false;\n\n    @if ($type == 'bool') {\n      $print: true;\n    }\n    @else if ($type == 'string') {\n      @if $query-fallback == breakpoint-get('no query fallbacks') {\n        $print: true;\n      }\n    }\n    @else if ($type == 'list') {\n      @each $wrapper in breakpoint-get('no query fallbacks') {\n        @if $query-fallback == $wrapper {\n          $print: true;\n        }\n      }\n    }\n\n    // Write Fallback\n    @if ($query-fallback != false) and ($print == true) {\n      $type-fallback: type-of($query-fallback);\n\n      @if ($type-fallback != 'bool') {\n        #{$query-fallback} & {\n          @content;\n        }\n      }\n      @else {\n        @content;\n      }\n    }\n  }\n\n  @include private-breakpoint-reset-contexts();\n}\n\n\n@mixin mq($query, $no-query: false) {\n  @include breakpoint($query, $no-query) {\n    @content;\n  }\n}\n","//////////////////////////////\n// Has Setting\n//////////////////////////////\n@function breakpoint-has($setting) {\n  @if map-has-key($breakpoint, $setting) {\n    @return true;\n  }\n  @else {\n    @return false;\n  }\n}\n\n//////////////////////////////\n// Get Settings\n//////////////////////////////\n@function breakpoint-get($setting) {\n  @if breakpoint-has($setting) {\n    @return map-get($breakpoint, $setting);\n  }\n  @else {\n    @return map-get($Breakpoint-Settings, $setting);\n  }\n}\n\n//////////////////////////////\n// Set Settings\n//////////////////////////////\n@function breakpoint-set($setting, $value) {\n  @if (str-index($setting, '-') or str-index($setting, '_')) and str-index($setting, ' ') == null {\n    @warn \"Words in Breakpoint settings should be separated by spaces, not dashes or underscores. Please replace dashes and underscores between words with spaces. Settings will not work as expected until changed.\";\n  }\n  $breakpoint: map-merge($breakpoint, ($setting: $value)) !global;\n  @return true;\n}\n\n@mixin breakpoint-change($setting, $value) {\n  $breakpoint-change: breakpoint-set($setting, $value);\n}\n\n@mixin breakpoint-set($setting, $value) {\n  @include breakpoint-change($setting, $value);\n}\n\n@mixin bkpt-change($setting, $value) {\n  @include breakpoint-change($setting, $value);\n}\n@mixin bkpt-set($setting, $value) {\n  @include breakpoint-change($setting, $value);\n}\n\n//////////////////////////////\n// Remove Setting\n//////////////////////////////\n@function breakpoint-reset($settings...) {\n  @if length($settings) == 1 {\n    $settings: nth($settings, 1);\n  }\n\n  @each $setting in $settings {\n    $breakpoint: map-remove($breakpoint, $setting) !global;\n  }\n  @return true;\n}\n\n@mixin breakpoint-reset($settings...) {\n  $breakpoint-reset: breakpoint-reset($settings);\n}\n\n@mixin bkpt-reset($settings...) {\n  $breakpoint-reset: breakpoint-reset($settings);\n}","//////////////////////////////\n// Private Breakpoint Variables\n//////////////////////////////\n$private-breakpoint-context-holder: ();\n$private-breakpoint-query-count: 0 !default;\n\n//////////////////////////////\n// Breakpoint Has Context\n// Returns whether or not you are inside a Breakpoint query\n//////////////////////////////\n@function breakpoint-has-context() {\n  @if length($private-breakpoint-query-count) {\n    @return true;\n  }\n  @else {\n    @return false;\n  }\n}\n\n//////////////////////////////\n// Breakpoint Get Context\n// $feature: Input feature to get it's current MQ context. Returns false if no context\n//////////////////////////////\n@function breakpoint-get-context($feature) {\n  @if map-has-key($private-breakpoint-context-holder, $feature) {\n    $get: map-get($private-breakpoint-context-holder, $feature);\n    // Special handling of no-query from get side so /false/ prepends aren't returned\n    @if $feature == 'no-query' {\n      @if type-of($get) == 'list' and length($get) > 1 and nth($get, 1) == false {\n        $get: nth($get, length($get));\n      }\n    }\n    @return $get;\n  }\n  @else {\n    @if breakpoint-has-context() and $feature == 'media' {\n      @return breakpoint-get('default media');\n    }\n    @else {\n      @return false;\n    }\n  }\n}\n\n//////////////////////////////\n// Private function to set context\n//////////////////////////////\n@function private-breakpoint-set-context($feature, $value) {\n  @if $value == 'monochrome' {\n    $feature: 'monochrome';\n  }\n\n  $current: map-get($private-breakpoint-context-holder, $feature);\n  @if $current and length($current) == $private-breakpoint-query-count {\n    @warn \"You have already queried against `#{$feature}`. Unexpected things may happen if you query against the same feature more than once in the same `and` query. Breakpoint is overwriting the current context with `#{$value}`\";\n  }\n\n  @if not map-has-key($private-breakpoint-context-holder, $feature) {\n    $v-holder: ();\n    @for $i from 1 to $private-breakpoint-query-count {\n      @if $feature == 'media' {\n        $v-holder: append($v-holder, breakpoint-get('default media'));\n      }\n      @else {\n        $v-holder: append($v-holder, false);\n      }\n    }\n    $v-holder: append($v-holder, $value);\n    $private-breakpoint-context-holder: map-merge($private-breakpoint-context-holder, ($feature: $v-holder)) !global;\n  }\n  @else {\n    $v-holder: map-get($private-breakpoint-context-holder, $feature);\n    $length: length($v-holder);\n    @for $i from $length to $private-breakpoint-query-count - 1 {\n      @if $feature == 'media' {\n        $v-holder: append($v-holder, breakpoint-get('default media'));\n      }\n      @else {\n        $v-holder: append($v-holder, false);\n      }\n    }\n    $v-holder: append($v-holder, $value);\n    $private-breakpoint-context-holder: map-merge($private-breakpoint-context-holder, ($feature: $v-holder)) !global;\n  }\n\n  @return true;\n}\n\n//////////////////////////////\n// Private function to reset context\n//////////////////////////////\n@mixin private-breakpoint-reset-contexts {\n  $private-breakpoint-context-holder: () !global;\n  $private-breakpoint-query-count: 0 !global;\n}","//////////////////////////////\n// Converts the input value to Base EMs\n//////////////////////////////\n@function breakpoint-to-base-em($value) {\n  $value-unit: unit($value);\n\n  // Will convert relative EMs into root EMs.\n  @if breakpoint-get('base font size') and type-of(breakpoint-get('base font size')) == 'number' and $value-unit == 'em' {\n    $base-unit: unit(breakpoint-get('base font size'));\n\n    @if $base-unit == 'px' or $base-unit == '%' or $base-unit == 'em' or $base-unit == 'pt' {\n      @return base-conversion($value) / base-conversion(breakpoint-get('base font size')) * 1em;\n    }\n    @else {\n      @warn '#{breakpoint-get(\\'base font size\\')} is not set in valid units for font size!';\n      @return false;\n    }\n  }\n  @else {\n    @return base-conversion($value);\n  }\n}\n\n@function base-conversion($value) {\n  $unit: unit($value);\n\n  @if $unit == 'px' {\n    @return $value / 16px * 1em;\n  }\n  @else if $unit == '%' {\n    @return $value / 100% * 1em;\n  }\n  @else if $unit == 'em' {\n    @return $value;\n  }\n  @else if $unit == 'pt' {\n    @return $value / 12pt * 1em;\n  }\n  @else {\n    @return $value;\n//    @warn 'Everything is terrible! What have you done?!';\n  }\n}\n\n//////////////////////////////\n// Returns whether the feature can have a min/max pair\n//////////////////////////////\n$breakpoint-min-max-features: 'color',\n                              'color-index',\n                              'aspect-ratio',\n                              'device-aspect-ratio',\n                              'device-height',\n                              'device-width',\n                              'height',\n                              'monochrome',\n                              'resolution',\n                              'width';\n\n@function breakpoint-min-max($feature) {\n  @each $item in $breakpoint-min-max-features {\n    @if $feature == $item {\n      @return true;\n    }\n  }\n  @return false;\n}\n\n//////////////////////////////\n// Returns whether the feature can have a string value\n//////////////////////////////\n$breakpoint-string-features:  'orientation',\n                              'scan',\n                              'color',\n                              'aspect-ratio',\n                              'device-aspect-ratio',\n                              'pointer',\n                              'luminosity';\n\n@function breakpoint-string-value($feature) {\n  @each $item in $breakpoint-string-features {\n    @if breakpoint-min-max($item) {\n      @if $feature == 'min-#{$item}' or $feature == 'max-#{$item}' {\n        @return true;\n      }\n    }\n    @else if $feature == $item {\n      @return true;\n    }\n  }\n  @return false;\n}\n\n//////////////////////////////\n// Returns whether the feature is a media type\n//////////////////////////////\n$breakpoint-media-types:  'all',\n                          'braille',\n                          'embossed',\n                          'handheld',\n                          'print',\n                          'projection',\n                          'screen',\n                          'speech',\n                          'tty',\n                          'tv';\n\n@function breakpoint-is-media($feature) {\n  @each $media in $breakpoint-media-types {\n    @if ($feature == $media) or ($feature == 'not #{$media}') or ($feature == 'only #{$media}') {\n      @return true;\n    }\n  }\n\n  @return false;\n}\n\n//////////////////////////////\n// Returns whether the feature can stand alone\n//////////////////////////////\n$breakpoint-single-string-features: 'color',\n                                    'color-index',\n                                    'grid',\n                                    'monochrome';\n\n@function breakpoint-single-string($feature) {\n  @each $item in $breakpoint-single-string-features {\n    @if $feature == $item {\n      @return true;\n    }\n  }\n  @return false;\n}\n\n//////////////////////////////\n// Returns whether the feature\n//////////////////////////////\n@function breakpoint-is-resolution($feature) {\n  $resolutions: 'device-pixel-ratio', 'dpr';\n\n  @if breakpoint-get('transform resolutions') {\n    $resolutions: append($resolutions, 'resolution');\n  }\n\n  @each $reso in $resolutions {\n    @if index($feature, $reso) or index($feature, 'min-#{$reso}') or index($feature, 'max-#{$reso}') {\n      @return true;\n    }\n  }\n\n  @return false;\n}\n","//////////////////////////////\n// Import Parser Pieces\n//////////////////////////////\n@import \"parsers/query\";\n@import \"parsers/single\";\n@import \"parsers/double\";\n@import \"parsers/triple\";\n@import \"parsers/resolution\";\n\n$Memo-Exists: function-exists(memo-get) and function-exists(memo-set);\n\n//////////////////////////////\n// Breakpoint Function\n//////////////////////////////\n@function breakpoint($query, $contexts...) {\n  $run: true;\n  $return: ();\n\n  // Grab the Memo Output if Memoization can be a thing\n  @if $Memo-Exists {\n    $return: memo-get(breakpoint, breakpoint $query $contexts);\n\n    @if $return != null {\n      $run: false;\n    }\n  }\n\n  @if not $Memo-Exists or $run {\n    // Internal Variables\n    $query-string: '';\n    $query-fallback: false;\n    $return: ();\n\n    // Reserve Global Private Breakpoint Context\n    $holder-context: $private-breakpoint-context-holder;\n    $holder-query-count: $private-breakpoint-query-count;\n\n    // Reset Global Private Breakpoint Context\n    $private-breakpoint-context-holder: () !global;\n    $private-breakpoint-query-count: 0 !global;\n\n\n    // Test to see if it's a comma-separated list\n    $or-list: if(list-separator($query) == 'comma', true, false);\n\n\n    @if ($or-list == false and breakpoint-get('legacy syntax') == false) {\n      $query-string: breakpoint-parse($query);\n    }\n    @else {\n      $length: length($query);\n\n      $last: nth($query, $length);\n      $query-fallback: breakpoint-no-query($last);\n\n      @if ($query-fallback != false) {\n        $length: $length - 1;\n      }\n\n      @if (breakpoint-get('legacy syntax') == true) {\n        $mq: ();\n\n        @for $i from 1 through $length {\n          $mq: append($mq, nth($query, $i), comma);\n        }\n\n        $query-string: breakpoint-parse($mq);\n      }\n      @else {\n        $query-string: '';\n        @for $i from 1 through $length {\n          $query-string: $query-string + if($i == 1, '', ', ') + breakpoint-parse(nth($query, $i));\n        }\n      }\n    }\n\n    $return: ('query': $query-string,\n        'fallback': $query-fallback,\n        'context holder': $private-breakpoint-context-holder,\n        'query count': $private-breakpoint-query-count\n    );\n    @if length($contexts) > 0 and nth($contexts, 1) != false {\n      @if $query-fallback != false {\n        $context-setter: private-breakpoint-set-context('no-query', $query-fallback);\n      }\n      $context-map: ();\n      @each $context in $contexts {\n        $context-map: map-merge($context-map, ($context: breakpoint-get-context($context)));\n      }\n      $return: map-merge($return, (context: $context-map));\n    }\n\n    // Reset Global Private Breakpoint Context\n    $private-breakpoint-context-holder: () !global;\n    $private-breakpoint-query-count: 0 !global;\n\n    @if $Memo-Exists {\n      $holder: memo-set(breakpoint, breakpoint $query $contexts, $return);\n    }\n  }\n\n  @return $return;\n}\n\n//////////////////////////////\n// General Breakpoint Parser\n//////////////////////////////\n@function breakpoint-parse($query) {\n  // Increase number of 'and' queries\n  $private-breakpoint-query-count: $private-breakpoint-query-count + 1 !global;\n\n  // Set up Media Type\n  $query-print: '';\n\n  $force-all: ((breakpoint-get('force all media type') == true) and (breakpoint-get('default media') == 'all'));\n  $empty-media: true;\n  @if ($force-all == true) or (breakpoint-get('default media') != 'all') {\n    // Force the print of the default media type if (force all is true and default media type is all) or (default media type is not all)\n    $query-print: breakpoint-get('default media');\n    $empty-media: false;\n  }\n\n\n  $query-resolution: false;\n\n  $query-holder: breakpoint-parse-query($query);\n\n\n\n  // Loop over each parsed out query and write it to $query-print\n  $first: true;\n\n  @each $feature in $query-holder {\n    $length: length($feature);\n\n    // Parse a single feature\n    @if ($length == 1) {\n      // Feature is currently a list, grab the actual value\n      $feature: nth($feature, 1);\n\n      // Media Type must by convention be the first item, so it's safe to flat override $query-print, which right now should only be the default media type\n      @if (breakpoint-is-media($feature)) {\n        @if ($force-all == true) or ($feature != 'all') {\n          // Force the print of the default media type if (force all is true and default media type is all) or (default media type is not all)\n          $query-print: $feature;\n          $empty-media: false;\n\n          // Set Context\n          $context-setter: private-breakpoint-set-context(media, $query-print);\n        }\n      }\n      @else {\n        $parsed: breakpoint-parse-single($feature, $empty-media, $first);\n        $query-print: '#{$query-print} #{$parsed}';\n        $first: false;\n      }\n    }\n    // Parse a double feature\n    @else if ($length == 2) {\n      @if (breakpoint-is-resolution($feature) != false) {\n        $query-resolution: $feature;\n      }\n      @else {\n        $parsed: null;\n        // If it's a string/number pair,\n        // we check to see if one is a single-string value,\n        // then we parse it as a normal double\n        $alpha: nth($feature, 1);\n        $beta: nth($feature, 2);\n        @if breakpoint-single-string($alpha) or breakpoint-single-string($beta) {\n          $parsed: breakpoint-parse-single($alpha, $empty-media, $first);\n          $query-print: '#{$query-print} #{$parsed}';\n          $first: false;\n          $parsed: breakpoint-parse-single($beta, $empty-media, $first);\n          $query-print: '#{$query-print} #{$parsed}';\n        }\n        @else {\n          $parsed: breakpoint-parse-double($feature, $empty-media, $first);\n          $query-print: '#{$query-print} #{$parsed}';\n          $first: false;\n        }\n      }\n    }\n    // Parse a triple feature\n    @else if ($length == 3) {\n      $parsed: breakpoint-parse-triple($feature, $empty-media, $first);\n      $query-print: '#{$query-print} #{$parsed}';\n      $first: false;\n    }\n\n  }\n\n  @if ($query-resolution != false) {\n    $query-print: breakpoint-build-resolution($query-print, $query-resolution, $empty-media, $first);\n  }\n\n  // Loop through each feature that's been detected so far and append 'false' to the the value list to increment their counters\n  @each $f, $v in $private-breakpoint-context-holder {\n    $v-holder: $v;\n    $length: length($v-holder);\n    @if length($v-holder) < $private-breakpoint-query-count {\n      @for $i from $length to $private-breakpoint-query-count {\n        @if $f == 'media' {\n          $v-holder: append($v-holder, breakpoint-get('default media'));\n        }\n        @else {\n          $v-holder: append($v-holder, false);\n        }\n      }\n    }\n    $private-breakpoint-context-holder: map-merge($private-breakpoint-context-holder, ($f: $v-holder)) !global;\n  }\n\n  @return $query-print;\n}\n","@function breakpoint-parse-query($query) {\n  // Parse features out of an individual query\n  $feature-holder: ();\n  $query-holder: ();\n  $length: length($query);\n\n  @if $length == 2 {\n    // If we've got a string/number, number/string, check to see if it's a valid string/number pair or two singles\n    @if (type-of(nth($query, 1)) == 'string' and type-of(nth($query, 2)) == 'number') or (type-of(nth($query, 1)) == 'number' and type-of(nth($query, 2)) == 'string') {\n\n      $number: '';\n      $value: '';\n\n      @if type-of(nth($query, 1)) == 'string' {\n        $number: nth($query, 2);\n        $value: nth($query, 1);\n      }\n      @else {\n        $number: nth($query, 1);\n        $value: nth($query, 2);\n      }\n\n      // If the string value can be a single value, check to see if the number passed in is a valid input for said single value. Fortunately, all current single-value options only accept unitless numbers, so this check is easy.\n      @if breakpoint-single-string($value) {\n        @if unitless($number) {\n          $feature-holder: append($value, $number, space);\n          $query-holder: append($query-holder, $feature-holder, comma);\n          @return $query-holder;\n        }\n      }\n      // If the string is a media type, split the query\n      @if breakpoint-is-media($value) {\n        $query-holder: append($query-holder, nth($query, 1));\n        $query-holder: append($query-holder, nth($query, 2));\n        @return $query-holder;\n      }\n      // If it's not a single feature, we're just going to assume it's a proper string/value pair, and roll with it.\n      @else {\n        $feature-holder: append($value, $number, space);\n        $query-holder: append($query-holder, $feature-holder, comma);\n        @return $query-holder;\n      }\n\n    }\n    // If they're both numbers, we assume it's a double and roll with that\n    @else if (type-of(nth($query, 1)) == 'number' and type-of(nth($query, 2)) == 'number') {\n      $feature-holder: append(nth($query, 1), nth($query, 2), space);\n      $query-holder: append($query-holder, $feature-holder, comma);\n      @return $query-holder;\n    }\n    // If they're both strings and neither are singles, we roll with that.\n    @else if (type-of(nth($query, 1)) == 'string' and type-of(nth($query, 2)) == 'string') {\n      @if not breakpoint-single-string(nth($query, 1)) and not breakpoint-single-string(nth($query, 2)) {\n        $feature-holder: append(nth($query, 1), nth($query, 2), space);\n        $query-holder: append($query-holder, $feature-holder, comma);\n        @return $query-holder;\n      }\n    }\n  }\n  @else if $length == 3 {\n    // If we've got three items and none is a list, we check to see\n    @if type-of(nth($query, 1)) != 'list' and type-of(nth($query, 2)) != 'list' and type-of(nth($query, 3)) != 'list' {\n      // If none of the items are single string values and none of the values are media values, we're good.\n      @if (not breakpoint-single-string(nth($query, 1)) and not breakpoint-single-string(nth($query, 2)) and not breakpoint-single-string(nth($query, 3))) and  ((not breakpoint-is-media(nth($query, 1)) and not breakpoint-is-media(nth($query, 2)) and not breakpoint-is-media(nth($query, 3)))) {\n        $feature-holder: append(nth($query, 1), nth($query, 2), space);\n        $feature-holder: append($feature-holder, nth($query, 3), space);\n        $query-holder: append($query-holder, $feature-holder, comma);\n        @return $query-holder;\n      }\n      // let's check to see if the first item is a media type\n      @else if breakpoint-is-media(nth($query, 1)) {\n        $query-holder: append($query-holder, nth($query, 1));\n        $feature-holder: append(nth($query, 2), nth($query, 3), space);\n        $query-holder: append($query-holder, $feature-holder);\n        @return $query-holder;\n      }\n    }\n  }\n\n  // If it's a single item, or if it's not a special case double or triple, we can simply return the query.\n  @return $query;\n}\n","//////////////////////////////\n// Import Pieces\n//////////////////////////////\n@import \"single/default\";\n\n@function breakpoint-parse-single($feature, $empty-media, $first) {\n  $parsed: '';\n  $leader: '';\n  // If we're forcing\n  @if not ($empty-media) or not ($first) {\n    $leader: 'and ';\n  }\n\n  // If it's a single feature that can stand alone, we let it\n  @if (breakpoint-single-string($feature)) {\n    $parsed: $feature;\n    // Set Context\n    $context-setter: private-breakpoint-set-context($feature, $feature);\n  }\n  // If it's not a stand alone feature, we pass it off to the default handler.\n  @else {\n    $parsed: breakpoint-parse-default($feature);\n  }\n\n  @return $leader + '(' + $parsed + ')';\n}\n","@function breakpoint-parse-default($feature) {\n  $default: breakpoint-get('default feature');\n\n  // Set Context\n  $context-setter: private-breakpoint-set-context($default, $feature);\n\n  @if (breakpoint-get('to ems') == true) and (type-of($feature) == 'number') {\n    @return '#{$default}: #{breakpoint-to-base-em($feature)}';\n  }\n  @else {\n    @return '#{$default}: #{$feature}';\n  }\n}\n","//////////////////////////////\n// Import Pieces\n//////////////////////////////\n@import \"double/default-pair\";\n@import \"double/double-string\";\n@import \"double/default\";\n\n@function breakpoint-parse-double($feature, $empty-media, $first) {\n  $parsed: '';\n  $leader: '';\n  // If we're forcing\n  @if not ($empty-media) or not ($first) {\n    $leader: 'and ';\n  }\n\n  $first: nth($feature, 1);\n  $second: nth($feature, 2);\n\n  // If we've got two numbers, we know we need to use the default pair because there are no media queries that has a media feature that is a number\n  @if type-of($first) == 'number' and type-of($second) == 'number' {\n    $parsed: breakpoint-parse-default-pair($first, $second);\n  }\n  // If they are both strings, we send it through the string parser\n  @else if type-of($first) == 'string' and type-of($second) == 'string' {\n    $parsed: breakpoint-parse-double-string($first, $second);\n  }\n  // If it's a string/number pair, we parse it as a normal double\n  @else {\n    $parsed: breakpoint-parse-double-default($first, $second);\n  }\n\n  @return $leader + $parsed;\n}\n","@function breakpoint-parse-default-pair($first, $second) {\n  $default: breakpoint-get('default pair');\n  $min: '';\n  $max: '';\n\n  // Sort into min and max\n  $min: min($first, $second);\n  $max: max($first, $second);\n\n  // Set Context\n  $context-setter: private-breakpoint-set-context(min-#{$default}, $min);\n  $context-setter: private-breakpoint-set-context(max-#{$default}, $max);\n\n  // Make them EMs if need be\n  @if (breakpoint-get('to ems') == true) {\n    $min: breakpoint-to-base-em($min);\n    $max: breakpoint-to-base-em($max);\n  }\n\n  @return '(min-#{$default}: #{$min}) and (max-#{$default}: #{$max})';\n}\n","@function breakpoint-parse-double-string($first, $second) {\n  $feature: '';\n  $value: '';\n\n  // Test to see which is the feature and which is the value\n  @if (breakpoint-string-value($first) == true) {\n    $feature: $first;\n    $value: $second;\n  }\n  @else if (breakpoint-string-value($second) == true) {\n    $feature: $second;\n    $value: $first;\n  }\n  @else {\n    @warn \"Neither #{$first} nor #{$second} is a valid media query name.\";\n  }\n\n  // Set Context\n  $context-setter: private-breakpoint-set-context($feature, $value);\n\n  @return '(#{$feature}: #{$value})';\n}","@function breakpoint-parse-double-default($first, $second) {\n  $feature: '';\n  $value: '';\n\n  @if type-of($first) == 'string' {\n    $feature: $first;\n    $value: $second;\n  }\n  @else {\n    $feature: $second;\n    $value: $first;\n  }\n\n  // Set Context\n  $context-setter: private-breakpoint-set-context($feature, $value);\n\n  @if (breakpoint-get('to ems') == true) {\n    $value: breakpoint-to-base-em($value);\n  }\n\n  @return '(#{$feature}: #{$value})'\n}\n","//////////////////////////////\n// Import Pieces\n//////////////////////////////\n@import \"triple/default\";\n\n@function breakpoint-parse-triple($feature, $empty-media, $first) {\n  $parsed: '';\n  $leader: '';\n\n  // If we're forcing\n  @if not ($empty-media) or not ($first) {\n    $leader: 'and ';\n  }\n\n  // separate the string features from the value numbers\n  $string: null;\n  $numbers: null;\n  @each $val in $feature {\n    @if type-of($val) == string {\n      $string: $val;\n    }\n    @else {\n      @if type-of($numbers) == 'null' {\n        $numbers: $val;\n      }\n      @else {\n        $numbers: append($numbers, $val);\n      }\n    }\n  }\n\n  $parsed: breakpoint-parse-triple-default($string, nth($numbers, 1), nth($numbers, 2));\n\n  @return $leader + $parsed;\n\n}\n","@function breakpoint-parse-triple-default($feature, $first, $second) {\n\n  // Sort into min and max\n  $min: min($first, $second);\n  $max: max($first, $second);\n\n  // Set Context\n  $context-setter: private-breakpoint-set-context(min-#{$feature}, $min);\n  $context-setter: private-breakpoint-set-context(max-#{$feature}, $max);\n\n  // Make them EMs if need be\n  @if (breakpoint-get('to ems') == true) {\n    $min: breakpoint-to-base-em($min);\n    $max: breakpoint-to-base-em($max);\n  }\n\n  @return '(min-#{$feature}: #{$min}) and (max-#{$feature}: #{$max})';\n}\n","@import \"resolution/resolution\";\n\n@function breakpoint-build-resolution($query-print, $query-resolution, $empty-media, $first) {\n  $leader: '';\n  // If we're forcing\n  @if not ($empty-media) or not ($first) {\n    $leader: 'and ';\n  }\n\n  @if breakpoint-get('transform resolutions') and $query-resolution {\n    $resolutions: breakpoint-make-resolutions($query-resolution);\n    $length: length($resolutions);\n    $query-holder: '';\n\n    @for $i from 1 through $length {\n      $query: '#{$query-print} #{$leader}#{nth($resolutions, $i)}';\n      @if $i == 1 {\n        $query-holder: $query;\n      }\n      @else {\n        $query-holder: '#{$query-holder}, #{$query}';\n      }\n    }\n\n    @return $query-holder;\n  }\n  @else {\n    // Return with attached resolution\n    @return $query-print;\n  }\n}\n","@function breakpoint-make-resolutions($resolution) {\n  $length: length($resolution);\n\n  $output: ();\n\n  @if $length == 2 {\n    $feature: '';\n    $value: '';\n\n    // Find which is number\n    @if type-of(nth($resolution, 1)) == 'number' {\n      $value: nth($resolution, 1);\n    }\n    @else {\n      $value: nth($resolution, 2);\n    }\n\n    // Determine min/max/standard\n    @if index($resolution, 'min-resolution') {\n      $feature: 'min-';\n    }\n    @else if index($resolution, 'max-resolution') {\n      $feature: 'max-';\n    }\n\n    $standard: '(#{$feature}resolution: #{$value})';\n\n    // If we're not dealing with dppx,\n    @if unit($value) != 'dppx' {\n      $base: 96dpi;\n      @if unit($value) == 'dpcm' {\n        $base: 243.84dpcm;\n      }\n      // Write out feature tests\n      $webkit: '';\n      $moz: '';\n      $webkit: '(-webkit-#{$feature}device-pixel-ratio: #{$value / $base})';\n      $moz: '(#{$feature}-moz-device-pixel-ratio: #{$value / $base})';\n      // Append to output\n      $output: append($output, $standard, space);\n      $output: append($output, $webkit, space);\n      $output: append($output, $moz, space);\n    }\n    @else {\n      $webkit: '';\n      $moz: '';\n      $webkit: '(-webkit-#{$feature}device-pixel-ratio: #{$value / 1dppx})';\n      $moz: '(#{$feature}-moz-device-pixel-ratio: #{$value / 1dppx})';\n      $fallback: '(#{$feature}resolution: #{$value / 1dppx * 96dpi})';\n      // Append to output\n      $output: append($output, $standard, space);\n      $output: append($output, $webkit, space);\n      $output: append($output, $moz, space);\n      $output: append($output, $fallback, space);\n    }\n\n  }\n\n  @return $output;\n}\n","@function breakpoint-no-query($query) {\n  @if type-of($query) == 'list' {\n    $keyword: nth($query, 1);\n\n    @if type-of($keyword) == 'string' and ($keyword == 'no-query' or $keyword == 'no query' or $keyword == 'fallback') {\n      @return nth($query, 2);\n    }\n    @else {\n      @return false;\n    }\n  }\n  @else {\n    @return false;\n  }\n}\n","////////////////////////\n// Default the Breakpoints variable\n////////////////////////\n$breakpoints: () !default;\n$BREAKPOINTS: () !default;\n\n////////////////////////\n// Respond-to API Mixin\n////////////////////////\n@mixin respond-to($context, $no-query: false) {\n  @if length($breakpoints) > 0 and length($BREAKPOINTS) == 0 {\n    @warn \"In order to avoid variable namespace collisions, we have updated the way to add breakpoints for respond-to. Please change all instances of `$breakpoints: add-breakpoint()` to `@include add-breakpoint()`. The `add-breakpoint()` function will be deprecated in a future release.\";\n    $BREAKPOINTS: $breakpoints !global;\n    $breakpoints: () !global;\n  }\n\n  @if type-of($BREAKPOINTS) != 'map' {\n    // Just in case someone writes gibberish to the $breakpoints variable.\n    @warn \"Your breakpoints aren't a map! `respond-to` expects a map. Please check the value of $BREAKPOINTS variable.\";\n    @content;\n  }\n  @else if map-has-key($BREAKPOINTS, $context) {\n    @include breakpoint(map-get($BREAKPOINTS, $context), $no-query) {\n      @content;\n    }\n  }\n  @else if not map-has-key($BREAKPOINTS, $context) {\n    @warn \"`#{$context}` isn't a defined breakpoint! Please add it using `$breakpoints: add-breakpoint(`#{$context}`, $value);`\";\n    @content;\n  }\n  @else {\n    @warn \"You haven't created any breakpoints yet! Make some already! `@include add-breakpoint($name, $bkpt)`\";\n    @content;\n  }\n}\n\n//////////////////////////////\n// Add Breakpoint to Breakpoints\n// TODO: Remove function in next release\n//////////////////////////////\n@function add-breakpoint($name, $bkpt, $overwrite: false) {\n  $output: ($name: $bkpt);\n\n  @if length($breakpoints) == 0 {\n    @return $output;\n  }\n  @else {\n    @if map-has-key($breakpoints, $name) and $overwrite != true {\n      @warn \"You already have a breakpoint named `#{$name}`, please choose another breakpoint name, or pass in `$overwrite: true` to overwrite the previous breakpoint.\";\n      @return $breakpoints;\n    }\n    @else if not map-has-key($breakpoints, $name) or $overwrite == true {\n      @return map-merge($breakpoints, $output);\n    }\n  }\n}\n\n@mixin add-breakpoint($name, $bkpt, $overwrite: false) {\n  $output: ($name: $bkpt);\n\n  @if length($BREAKPOINTS) == 0 {\n    $BREAKPOINTS: $output !global;\n  }\n  @else {\n    @if map-has-key($BREAKPOINTS, $name) and $overwrite != true {\n      @warn \"You already have a breakpoint named `#{$name}`, please choose another breakpoint name, or pass in `$overwrite: true` to overwrite the previous breakpoint.\";\n      $BREAKPOINTS: $BREAKPOINTS !global;\n    }\n    @else if not map-has-key($BREAKPOINTS, $name) or $overwrite == true {\n      $BREAKPOINTS: map-merge($BREAKPOINTS, $output) !global;\n    }\n  }\n}\n\n@function get-breakpoint($name: false) {\n  @if $name == false {\n    @return $BREAKPOINTS;\n  }\n  @else {\n    @return map-get($BREAKPOINTS, $name);\n  }\n}\n","@mixin legacy-settings-warning {\n  $legacyVars: (\n    'default-media': 'default media',\n    'default-feature': 'default feature',\n    'force-media-all': 'force all media type',\n    'to-ems': 'to ems',\n    'resolutions': 'transform resolutions',\n    'no-queries': 'no queries',\n    'no-query-fallbacks': 'no query fallbacks',\n    'base-font-size': 'base font size',\n    'legacy-syntax': 'legacy syntax'\n  );\n\n  @each $legacy, $new in $legacyVars {\n    @if global-variable-exists('breakpoint-' + $legacy) {\n      @warn \"In order to avoid variable namspace collisions, we have updated the way to change settings for Breakpoint. Please change all instances of `$breakpoint-#{$legacy}: {{setting}}` to `@include breakpoint-set('#{$new}', {{setting}})`. Variable settings, as well as this warning will be deprecated in a future release.\"\n    }\n  };\n\n  //////////////////////////////\n  // Hand correct each setting\n  //////////////////////////////\n  @if global-variable-exists('breakpoint-default-media') and $breakpoint-default-media != breakpoint-get('default media') {\n    @include breakpoint-set('default media', $breakpoint-default-media);\n  }\n  @if global-variable-exists('breakpoint-default-feature') and $breakpoint-default-feature != breakpoint-get('default feature') {\n    @include breakpoint-set('default feature', $breakpoint-default-feature);\n  }\n  @if global-variable-exists('breakpoint-force-media-all') and $breakpoint-force-media-all != breakpoint-get('force all media type') {\n    @include breakpoint-set('force all media type', $breakpoint-force-media-all);\n  }\n  @if global-variable-exists('breakpoint-to-ems') and $breakpoint-to-ems != breakpoint-get('to ems') {\n    @include breakpoint-set('to ems', $breakpoint-to-ems);\n  }\n  @if global-variable-exists('breakpoint-resolutions') and $breakpoint-resolutions != breakpoint-get('transform resolutions') {\n    @include breakpoint-set('transform resolutions', $breakpoint-resolutions);\n  }\n  @if global-variable-exists('breakpoint-no-queries') and $breakpoint-no-queries != breakpoint-get('no queries') {\n    @include breakpoint-set('no queries', $breakpoint-no-queries);\n  }\n  @if global-variable-exists('breakpoint-no-query-fallbacks') and $breakpoint-no-query-fallbacks != breakpoint-get('no query fallbacks') {\n    @include breakpoint-set('no query fallbacks', $breakpoint-no-query-fallbacks);\n  }\n  @if global-variable-exists('breakpoint-base-font-size') and $breakpoint-base-font-size != breakpoint-get('base font size') {\n    @include breakpoint-set('base font size', $breakpoint-base-font-size);\n  }\n  @if global-variable-exists('breakpoint-legacy-syntax') and $breakpoint-legacy-syntax != breakpoint-get('legacy syntax') {\n    @include breakpoint-set('legacy syntax', $breakpoint-legacy-syntax);\n  }\n}","@import \"functions\";\n@import \"z-index\";\n@import \"media-queries\";\n@import \"variables\";\n@import \"uniboard\";\n@import \"mixins\";\n@import \"extends\";\n@import \"flex\";\n@import \"box\";\n@import \"fluid-size\";\n","/// Z-indexes map, gathering all Z layers of the application\n/// @access private\n/// @type Map\n/// @prop {String} key - Layer’s name\n/// @prop {Number} value - Z value mapped to the key\n$z-indexes: (\"cg__promotion\": 205, \"cg__piece.dragging\": 204, \"cg__piece.anim\": 3, \"cg__svg\": 2, \"cg__piece\": 2, \"cg__piece.fading\": 1, \"powertip\": 120, \"inquiry\": 111, \"zen-toggle\": 110, \"modal\": 110, \"mselect\": 110, \"topnav\": 110, \"fullscreen-mask\": 109, \"dropdown\": 108, \"context-menu\": 107, \"site-header\": 106, \"reconnecting\": 105, \"tour-reminder\": 104, \"nag-circle\": 103, \"mz-menu\": 4, \"above-link-overlay\": 3, \"friend-box\": 2, \"link-overlay\": 2, \"game-bookmark\": 2, \"subnav-side\": 2, \"default\": 0);\n\n/// Get a z-index value from a layer name\n/// @access public\n/// @param {String} $layer - Layer’s name\n/// @return {Number}\n/// @require $z-indexes\n@function z($layer) {\n  @return map-get($z-indexes, $layer);\n}\n","/* Widths */\n\n$mq-xx-small: min-width 500px;\n$mq-x-small: min-width 650px;\n$mq-small: min-width 800px;\n$mq-medium: min-width 980px;\n$mq-large: min-width 1120px;\n$mq-x-large: min-width 1260px;\n\n$mq-not-xx-small: max-width 499px;\n$mq-not-x-small: max-width 649px;\n$mq-not-small: max-width 799px;\n$mq-not-medium: max-width 979px;\n$mq-not-x-large: max-width 1259px;\n\n/* Heights */\n\n$mq-x-short: min-height 400px;\n$mq-short: min-height 500px;\n$mq-tall: min-height 600px;\n$mq-x-tall: min-height 700px;\n\n$mq-not-x-short: max-height 399px;\n\n/* Orientations */\n\n$mq-portrait: orientation portrait;\n$mq-landscape: orientation landscape;\n\n/* Capabilities */\n\n$mq-hover-yes: \"hover: hover\";\n$mq-hover-no: hover none;\n\n/* Aliases */\n\n$mq-main-margin: $mq-small;\n\n$mq-topnav-visible: $mq-medium;\n$mq-topnav-hidden: $mq-not-medium;\n\n$mq-site-header-tall: $mq-tall;\n\n$mq-subnav-top: $mq-not-small;\n$mq-subnav-side: $mq-small;\n\n$mq-zoom-enabled: $mq-small $mq-short;\n","$debug: false;\n\n$font-path: \"../font\";\n$img-path: \"../images\";\n\n$viewport-min-width: 320px;\n\n$block-gap: 2vmin;\n$block-gap-half: 1vmin;\n\n$block-gap-h: 2vh;\n$block-gap-w: 2vw;\n$block-gap-w-half: 1vw;\n\n$box-radius-size: 3px;\n\n$site-header-tall-height: 60px;\n$site-header-short-height: 40px;\n\n$transition-duration: 150ms;\n\n$main-max-width: 1300px !default;\n\n$main-margin: var(--main-margin);\n$site-header-height: var(--site-header-height);\n\n$site-header-margin: var(--site-header-margin);\n\n$site-header-outer-height: calc(#{$site-header-height} + #{$site-header-margin});\n","/* Uniboard: keep the same page layout accross pages */\n\n$mq-board-resizable: $mq-small;\n$mq-col1-uniboard: $mq-not-small $mq-portrait;\n$mq-col2-uniboard: $mq-small, $mq-landscape;\n$mq-col3-uniboard: $mq-x-large;\n\n/* when the width is appropriate for col1, but landscape prevents it */\n$mq-col2-uniboard-squeeze: $mq-not-small $mq-landscape;\n\n$col3-uniboard-side: minmax(230px, 20vw);\n$col3-uniboard-table: minmax(240px, 400px);\n$col3-uniboard-controls: 3rem;\n\n$col3-uniboard-min-width: calc(70vmin * var(--board-scale));\n$col3-uniboard-max-width: calc(100vh * var(--board-scale) - #{$site-header-outer-height} - #{$col3-uniboard-controls});\n$col3-uniboard-width: minmax($col3-uniboard-min-width, $col3-uniboard-max-width);\n\n$col3-uniboard-default-scale: 0.9;\n\n// zoom: 85%\n$col3-uniboard-default-min-width: 500px;\n$col3-uniboard-default-max-width: calc(100vh * #{$col3-uniboard-default-scale} - #{$site-header-outer-height} - #{$col3-uniboard-controls});\n$col3-uniboard-default-width: minmax(#{$col3-uniboard-default-min-width}, #{$col3-uniboard-default-max-width});\n\n$col2-uniboard-table: $col3-uniboard-table;\n$col2-uniboard-controls: $col3-uniboard-controls;\n$col2-uniboard-width: $col3-uniboard-width;\n$col2-uniboard-default-width: $col3-uniboard-default-width;\n\n$col2-uniboard-squeeze-table: minmax(200px, 240px);\n$col2-uniboard-squeeze-width: minmax(calc(55vmin), calc(100vh - #{$site-header-outer-height} - #{$block-gap}));\n\n$col1-uniboard-controls: $col2-uniboard-controls;\n","@mixin box-radius {\n  border-radius: $box-radius-size;\n}\n\n@mixin box-shadow {\n  box-shadow: $box-shadow;\n}\n\n@mixin box-neat {\n  @include box-radius;\n  @include box-shadow;\n}\n\n@mixin debug-zoom-input {\n  #zoom-input {\n    display: none;\n\n    @include breakpoint($mq-zoom-enabled) {\n      display: block;\n      position: fixed;\n      bottom: 3px;\n      right: 3px;\n      width: 10vw;\n    }\n  }\n}\n\n@mixin transition($prop: all, $dur: $transition-duration) {\n  transition: $prop $dur;\n}\n\n@mixin hoverflow {\n  overflow-y: auto;\n\n  @media (hover: hover) {\n    overflow: hidden;\n\n    &:hover {\n      overflow-y: auto;\n    }\n  }\n}\n\n@mixin hide {\n  display: none;\n\n  .blind-mode & {\n    display: inherit;\n  }\n}\n\n@mixin ellipsis {\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n@mixin crosstable-large {\n  .crosstable__users {\n    flex: 7 1 auto;\n  }\n}\n\n@mixin crosstable-small {\n  .crosstable__users {\n    flex: 1 1 auto;\n  }\n}\n\n/* atm only chrome supports min-content, max-content */\n@mixin proper-grid {\n  @supports (height: max-content) {\n    @content;\n  }\n}\n\n@mixin body-fixed-scroll {\n  body {\n    /* prevents scroll bar flicker when dragging a piece out */\n    overflow-y: scroll;\n  }\n}\n","%base-font-fallback {\n  font-family: 'Noto Sans', Sans-Serif;\n}\n\n%base-font {\n  font-family: 'Noto Sans';\n}\n\n%roboto {\n  font-family: 'Roboto';\n}\n\n%roboto-fat {\n  font-family: 'Roboto';\n  font-weight: 600;\n}\n\n%chess-font {\n  font-family: 'Noto Chess', 'Noto Sans';\n}\n\n%san {\n  @extend %chess-font;\n\n  .piece-letter & {\n    @extend %base-font;\n  }\n}\n\n/* text printed directly on the page background deserves special treatment (transp theme) */\n%page-font {\n  color: $c-font-page;\n}\n\n%page-text {\n  @extend %page-font, %page-text-shadow !optional;\n}\n\n%page-link {\n  @extend %page-link-font !optional;\n\n  @extend %page-text-shadow !optional;\n}\n\n%metal {\n  @include metal;\n}\n\n%metal-hover {\n  @include metal-hover;\n}\n\n%page-metal {\n  @include page-metal;\n}\n\n%page-metal-hover {\n  @include page-metal;\n}\n\n%metal-bg {\n  @include metal-bg;\n}\n\n%active-inset-shadow {\n  box-shadow: 0 3px 4px hsla(0, 0, 0, 0.15) inset;\n}\n\n%active {\n  @extend %active-inset-shadow;\n\n  background: #bd111f;\n  color: #fff;\n  text-shadow: 1px 1px 1px white !important;\n}\n\n#trainer group.radio input:checked + label{\n  background: #0456bc;\n}\n\n%active-hover {\n  background: mix(white, $c-accent, 20%);\n}\n\n%active-soft {\n  @extend %active-inset-shadow;\n\n  background: #0456bc;\n  color: #ffffff;\n  text-shadow: 1px 1px 1px $c-font-shadow !important;\n  font-weight: bold;\n}\n\n%dropdown-shadow {\n  box-shadow: -1px 5px 6px rgba(0, 0, 0, 0.3);\n}\n\n%popup-shadow {\n  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);\n}\n\n%button-shadow {\n  box-shadow: 0 2px 5px 0 hsla(0, 0, 0%, 0.225);\n}\n\n%button-raised-shadow {\n  box-shadow: 0 4px 10px 0px hsla(0, 0, 0, 0.225);\n}\n\n%button-none {\n  background: none;\n  border: none;\n  outline: none;\n  color: $c-font;\n}\n\n%checkbox {\n  @extend %box-radius;\n\n  -webkit-appearance: none;\n  background: $c-bg-page;\n  border: 1px solid $c-bg-low;\n  display: inline-block;\n  padding: .5em;\n\n  &:checked {\n    background: #0456bc;\n    border-color: #0456bc;\n  }\n}\n\n%focus-shadow {\n  box-shadow: 0 0 12px $c-font-dim;\n}\n\n%nowrap-hidden {\n  white-space: nowrap;\n  overflow: hidden;\n}\n\n%nowrap-ellipsis {\n  @extend %ellipsis;\n\n  white-space: nowrap;\n}\n\n%box-padding {\n  padding: 5vh var(--box-padding);\n}\n\n%box-padding-horiz {\n  padding: 0 var(--box-padding);\n}\n\n%break-word {\n  overflow-wrap: break-word;\n  word-break: break-word;\n}\n\n%break-word-hard {\n  overflow-wrap: break-word;\n  word-break: break-all;\n\n  /* support: firefox */\n  word-break: break-word;\n}\n\n%break-nope {\n  overflow-wrap: normal;\n  word-break: normal;\n}\n\n%ellipsis {\n  @include ellipsis;\n}\n\n%square {\n  position: relative;\n  display: block;\n  height: 0;\n  padding-bottom: 100%;\n  width: 100%;\n}\n\n%video {\n  position: relative;\n  display: block;\n  height: 0;\n  padding-bottom: 56.25%;\n\n  /* 16/9 */\n  // padding-bottom: 75%; /* 4/3 */\n  width: 100%;\n\n  > * {\n    @extend %abs-100;\n\n    border: none;\n  }\n}\n\n%data-icon {\n  font-size: 1.2em;\n  vertical-align: middle;\n  font-family: 'lichess';\n  font-style: normal;\n  font-weight: normal;\n  text-transform: none;\n  speak: none;\n  content: attr(data-icon);\n  opacity: 0.9;\n}\n\n%data-icon-top {\n  &::before {\n    vertical-align: text-top;\n  }\n}\n\n%fullscreen-mask {\n  position: fixed;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  background: $c-page-mask;\n  z-index: z(\"fullscreen-mask\");\n}\n\n%link-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  z-index: z(\"link-overlay\");\n}\n\n%abs-100 {\n  position: absolute;\n  width: 100%;\n  height: 100%;\n}\n","%flex-wrap {\n  display: flex;\n  flex-flow: row wrap;\n}\n\n%flex-center {\n  /* extends %flex-wrap */\n  display: flex;\n  flex-flow: row wrap;\n  align-items: center;\n}\n\n%flex-center-nowrap {\n  display: flex;\n  flex-flow: row nowrap;\n  align-items: center;\n}\n\n%flex-between {\n  /* extends %flex-center */\n  display: flex;\n  flex-flow: row wrap;\n  align-items: center;\n  justify-content: space-between;\n}\n\n%flex-between-nowrap {\n  /* extends %flex-center */\n  display: flex;\n  flex-flow: row nowrap;\n  align-items: center;\n  justify-content: space-between;\n}\n\n%flex-between-stretch {\n  display: flex;\n  flex-flow: row wrap;\n  justify-content: space-between;\n  align-items: stretch;\n}\n\n%flex-around {\n  /* extends %flex-center */\n  display: flex;\n  flex-flow: row wrap;\n  align-items: center;\n  justify-content: space-around;\n}\n\n%flex-column {\n  display: flex;\n  flex-flow: column;\n}\n","%box-radius {\n  @include box-radius;\n}\n\n%box-radius-force {\n  @extend %box-radius;\n\n  overflow: hidden;\n\n  /* helps with clipping background into border-radius */\n}\n\n%box-radius-left {\n  border-radius: $box-radius-size 0 0 $box-radius-size;\n}\n\n%box-radius-right {\n  border-radius: 0 $box-radius-size $box-radius-size 0;\n}\n\n%box-radius-top {\n  border-radius: $box-radius-size $box-radius-size 0 0;\n}\n\n%box-radius-bottom {\n  border-radius: 0 0 $box-radius-size $box-radius-size;\n}\n\n%box-radius-top-left {\n  border-radius: $box-radius-size 0 0 0;\n}\n\n%box-radius-top-right {\n  border-radius: 0 $box-radius-size 0 0;\n}\n\n%box-shadow {\n  @include box-shadow;\n}\n\n%box-neat {\n  @extend %box-shadow, %box-radius;\n}\n\n%box-neat-top {\n  @extend %box-shadow, %box-radius-top;\n}\n\n%box-neat-force {\n  @extend %box-shadow, %box-radius-force;\n}\n","$vp-min-width: 320px !default;\n$vp-max-width: 1200px !default;\n\n@function strip-unit($value) {\n  @return $value / ($value * 0 + 1);\n}\n\n@mixin fluid-size($prop, $min-size, $max-size, $min-vw: $vp-min-width, $max-vw: $vp-max-width) {\n  $u1: unit($min-vw);\n  $u2: unit($max-vw);\n  $u3: unit($min-size);\n  $u4: unit($max-size);\n\n  @if $u1 == $u2 and $u1 == $u3 and $u1 == $u4 {\n    & {\n      #{$prop}: $min-size;\n\n      @media (min-width: $min-vw) {\n        #{$prop}: calc(#{$min-size} + #{strip-unit($max-size - $min-size)} * ((100vw - #{$min-vw}) / #{strip-unit($max-vw - $min-vw)}));\n      }\n\n      @media (min-width: $max-vw) {\n        #{$prop}: $max-size;\n      }\n    }\n  }\n  @else {\n    @error \"fluid-size requires that all values have the same unit\";\n  }\n}\n","html {\n  box-sizing: border-box;\n  min-height: 100%;\n}\n\n*, *::before, *::after {\n  box-sizing: inherit;\n  margin: 0;\n  padding: 0;\n}\n\nbody {\n  background-color: $c-bg-page;\n  background-image: $c-bg-page-img;\n  background-size: $c-bg-page-bs;\n  color: $c-font;\n  overflow-x: hidden;\n\n  &.fixed-scroll {\n    /* prevents scroll bar flicker when dragging a piece out */\n    overflow-y: scroll;\n  }\n}\n\na {\n  color: $c-link;\n  text-decoration: none;\n\n  &:hover,\n  &:active,\n  &:focus {\n    color: $c-link-hover;\n  }\n}\n\np {\n  margin-bottom: 1em;\n}\n\nem, i {\n  font-style: normal;\n}\n\nli {\n  list-style: none;\n}\n\ntime {\n  font-size: 90%;\n  opacity: 0.9;\n\n  /* don't use c-color-dim, it overrides too hard */\n}\n\nhr {\n  margin: 1.5rem 0;\n  border: 0;\n  height: 1px;\n  background: $c-border;\n}\n\nsmall {\n  font-size: .9em;\n}\n\ntable, tbody, tfoot, thead, tr, th, td {\n  border: 0;\n  font-size: 100%;\n  font: inherit;\n  vertical-align: middle;\n  text-align: inherit;\n}\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n","@function local-font($path) {\n  @return url(#{$font-path}/#{$path});\n}\n\n@font-face {\n  font-family: \"lichess\";\n  src: local-font(\"lichess.woff2\") format(\"woff2\"), local-font(\"lichess.woff\") format(\"woff\");\n  font-display: block;\n  font-weight: normal;\n  font-style: normal;\n}\n\n@font-face {\n  font-family: 'Noto Chess';\n  src: local-font(\"lichess.chess.woff2\") format(\"woff2\"), local-font(\"lichess.chess.woff\") format(\"woff\");\n}\n\n/* cyrillic-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6DRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;\n}\n\n/* cyrillic */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr4TRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;\n}\n\n/* devanagari */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr5DRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;\n}\n\n/* greek-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6TRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+1F00-1FFF;\n}\n\n/* greek */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr5jRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0370-03FF;\n}\n\n/* vietnamese */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6jRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;\n}\n\n/* latin-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr6zRAW_0.woff2) format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n\n/* latin */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 400;\n\n  // src: local('Noto Sans'), local('NotoSans'), url(https://fonts.gstatic.com/s/notosans/v7/o-0IIpQlx3QUlC5A4PNr5TRA.woff2) format('woff2');\n  src: local(\"Noto Sans\"), local(\"NotoSans\"), local-font(\"noto-sans-latin.woff2\") format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;\n}\n\n/* cyrillic-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVadyB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;\n}\n\n/* cyrillic */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVYNyB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;\n}\n\n/* devanagari */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVZdyB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;\n}\n\n/* greek-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVaNyB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+1F00-1FFF;\n}\n\n/* greek */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVZ9yB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0370-03FF;\n}\n\n/* vietnamese */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVa9yB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;\n}\n\n/* latin-ext */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVatyB1Wk.woff2) format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n\n/* latin */\n@font-face {\n  font-family: 'Noto Sans';\n  font-style: normal;\n  font-weight: 700;\n\n  // src: local('Noto Sans Bold'), local('NotoSans-Bold'), url(https://fonts.gstatic.com/s/notosans/v7/o-0NIpQlx3QUlC5A4PNjXhFVZNyB.woff2) format('woff2');\n  src: local(\"Noto Sans Bold\"), local(\"NotoSans-Bold\"), local-font(\"noto-sans-bold-latin.woff2\") format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;\n}\n\n/* cyrillic-ext */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCRc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;\n}\n\n/* cyrillic */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fABc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;\n}\n\n/* greek-ext */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCBc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+1F00-1FFF;\n}\n\n/* greek */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fBxc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+0370-03FF;\n}\n\n/* vietnamese */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fCxc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;\n}\n\n/* latin-ext */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fChc4EsA.woff2) format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n\n/* latin */\n@font-face {\n  font-family: 'Roboto';\n  font-style: normal;\n  font-weight: 300;\n\n  // src: local('Roboto Light'), local('Roboto-Light'), url(https://fonts.gstatic.com/s/roboto/v18/KFOlCnqEu92Fr1MmSU5fBBc4.woff2) format('woff2');\n  src: local(\"Roboto Light\"), local(\"Roboto-Light\"), local-font(\"roboto-light-latin.woff2\") format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;\n}\n","html {\n  @extend %base-font-fallback;\n\n  @include fluid-size(\"font-size\", 12px, 14px);\n\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\nh1,\nh2,\nh3,\nh4 {\n  @extend %roboto;\n\n  font-weight: normal;\n  font-size: 1em;\n}\n\nh1 {\n  @include fluid-size(\"font-size\", 20px, 40px);\n\n  margin-bottom: 5vh;\n\n  a {\n    color: $c-link-dim;\n\n    &:hover {\n      color: $c-link;\n    }\n  }\n}\n\nh2 {\n  @include fluid-size(\"font-size\", 16px, 30px);\n}\n\n.ninja-title {\n  @extend %base-font;\n\n  font-size: 1em;\n}\n",".is::before,\n[data-icon]::before,\n.is-after::after {\n  @extend %data-icon;\n}\n\n.is.text::before,\n.text[data-icon]::before {\n  margin-right: .4em;\n}\n\n.user-link.online .line,\n.is-green::before {\n  color: #bd111f;\n}\n\n.is-red::before {\n  color: $c-bad;\n}\n\n.is-gold::before {\n  color: $c-brag;\n}\n","@import \"board-2d\";\n\ncg-board {\n  @extend %box-shadow, %abs-100;\n\n  top: 0;\n  left: 0;\n  user-select: none;\n  line-height: 0;\n  background-size: cover;\n\n  .manipulable & {\n    cursor: pointer;\n  }\n}\n\nsquare {\n  position: absolute;\n  width: 12.5%;\n  height: 12.5%;\n  pointer-events: none;\n\n  &.move-dest {\n    background: radial-gradient(rgba(20, 85, 30, 0.5) 19%, rgba(0, 0, 0, 0) 20%);\n    pointer-events: auto;\n  }\n\n  &.premove-dest {\n    background: radial-gradient(rgba(20, 30, 85, 0.5) 19%, rgba(0, 0, 0, 0) 20%);\n    pointer-events: auto;\n  }\n\n  &.oc.move-dest {\n    background: radial-gradient(transparent 0%, transparent 80%, rgba(20, 85, 0, 0.3) 80%);\n  }\n\n  &.oc.premove-dest {\n    background: radial-gradient(transparent 0%, transparent 80%, rgba(20, 30, 85, 0.2) 80%);\n  }\n\n  body.green &.last-move,\n  body.green-plastic &.last-move,\n  body.marble &.last-move {\n    background-color: rgba(0, 155, 199, 0.41);\n  }\n\n  &.last-move {\n    will-change: transform;\n    background-color: rgba(155, 199, 0, 0.41);\n  }\n\n  &.check {\n    background: radial-gradient(ellipse at center, rgba(255, 0, 0, 1) 0%, rgba(231, 0, 0, 1) 25%, rgba(169, 0, 0, 0) 89%, rgba(158, 0, 0, 0) 100%);\n  }\n\n  &.selected {\n    background-color: rgba(20, 85, 30, 0.5);\n  }\n\n  &.current-premove {\n    background-color: rgba(20, 30, 85, 0.5) !important;\n  }\n\n  &.move-dest:hover {\n    background: rgba(20, 85, 30, 0.3);\n  }\n\n  &.premove-dest:hover {\n    background: rgba(20, 30, 85, 0.2);\n  }\n\n  &.bh1 piece {\n    opacity: 0.98;\n  }\n}\n\npiece {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 12.5%;\n  height: 12.5%;\n  background-size: cover;\n  z-index: z(\"cg__piece\");\n  will-change: transform;\n  pointer-events: none;\n\n  &.dragging {\n    cursor: move;\n    z-index: z(\"cg__piece.dragging\");\n  }\n\n  &.anim {\n    z-index: z(\"cg__piece.anim\");\n  }\n\n  &.fading {\n    z-index: z(\"cg__piece.fading\");\n    opacity: 0.5;\n  }\n\n  &.ghost {\n    opacity: 0.3;\n  }\n}\n\ncg-helper {\n  position: absolute;\n  width: 12.5%;\n  padding-bottom: 12.5%;\n  display: table;\n\n  /* hack: round to full pixel size in chrome */\n  bottom: 0;\n}\n\ncg-container {\n  position: absolute;\n  width: 800%;\n  height: 800%;\n  display: block;\n  bottom: 0;\n}\n\n.cg-wrap svg {\n  overflow: hidden;\n  position: absolute;\n  top: 0px;\n  left: 0px;\n  width: 100%;\n  height: 100%;\n  pointer-events: none;\n  z-index: z(\"cg__svg\");\n  opacity: 0.6;\n\n  image {\n    opacity: 0.5;\n  }\n}\n","$board-image-path: \"../images/board\";\n\n$board-files: (\"blue\": \"svg/blue.svg\", \"blue2\": \"blue2.jpg\", \"blue-marble\": \"blue-marble.jpg\", \"wood2\": \"wood2.jpg\", \"wood3\": \"wood3.jpg\", \"wood4\": \"wood4-1024.jpg\", \"blue3\": \"blue3.jpg\", \"marble\": \"marble.jpg\", \"brown\": \"svg/brown.svg\", \"green\": \"svg/green.svg\", \"green-plastic\": \"green-plastic.png\", \"olive\": \"olive.jpg\", \"purple\": \"svg/purple.svg\", \"purple-diag\": \"purple-diag.png\", \"grey\": \"grey.jpg\", \"wood\": \"wood-1024.jpg\", \"canvas\": \"canvas2-1024.jpg\", \"leather\": \"leather-1024.jpg\", \"metal\": \"metal-1024.jpg\", \"maple\": \"maple.jpg\", \"maple2\": \"maple2.jpg\", \"newspaper\": \"newspaper.png\", \"pink\": \"pink-pyramid.png\", \"ic\": \"svg/ic.svg\");\n\n@each $color, $file in $board-files {\n  .#{$color} .is2d cg-board {\n    background-image: url(../images/board/#{$file});\n  }\n}\n",".main-board {\n  @extend %square;\n\n  &__preload {\n    position: absolute;\n  }\n\n  .cg-wrap {\n    @extend %abs-100;\n  }\n}\n\n.mini-board, .mini-game .cg-wrap {\n  @extend %square;\n}\n",".mini-game {\n  @extend %nowrap-hidden;\n\n  display: block;\n\n  &, &:hover {\n    color: $c-font;\n  }\n\n  &__player {\n    @extend %flex-between-nowrap;\n\n    padding: 3px 2px 0 2px;\n\n    &:first-child {\n      padding: 0 2px 2px 2px;\n    }\n  }\n\n  &__user {\n    overflow: hidden;\n  }\n\n  .rating {\n    @extend %roboto;\n\n    font-size: .9em;\n    margin-left: 1ch;\n  }\n\n  &__clock {\n    @extend %roboto;\n\n    padding: 0 1ch;\n\n    &.clock--run {\n      color: $c-accent;\n      font-weight: bold;\n    }\n  }\n\n  &__result {\n    font-weight: bold;\n    margin-right: 1ch;\n  }\n}\n","body {\n  background: none;\n  overflow: hidden;\n}\n\n.embedded {\n  display: block;\n  background: $c-bg-page;\n  padding: .3em;\n  color: $c-font !important;\n\n  cg-board {\n    box-shadow: none;\n  }\n\n  .text {\n    display: block;\n    text-align: center;\n    margin: .3em 0;\n  }\n}\n"],"names":[],"mappings":"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"} */
