html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  -webkit-font-smoothing: subpixel-antialiased; }

em {
  font-style: italic; }

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block; }

body {
  line-height: 1; }

ol,
ul {
  list-style: none; }

blockquote,
q {
  quotes: none; }

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none; }

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

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

body {
  height: 100%; }

html, body {
  margin: 0;
  padding: 0;
  height: 100%; }

html {
  font-size: 10px;
  text-rendering: optimizelegibility; }

body, input {
  font-family: Georgia, Times, "Times New Roman", serif; }

body {
  background-color: #fff;
  color: #000;
  font-size: 2.2rem;
  min-width: 320px;
  width: 100%; }

body #wrapper {
  min-height: 100%;
  position: relative;
  margin: 0;
  font-size: 2.2rem; }

a {
  color: #362cb2;
  text-decoration: underline; }

a:visited, a.visited {
  color: #a60003; }

sup, sub {
  font-size: 2rem;
  font-weight: bold;
  position: relative;
  display: inline-block;
  margin: 0 0.3rem; }

sup {
  top: -1rem; }

sub {
  bottom: -0.5rem; }

em {
  font-style: oblique; }

strong {
  font-weight: bold; }

body header {
  text-align: center;
  padding-top: 3rem; }

#wrapper > header h1 {
  border-bottom: 0.6rem solid #76409d; }

nav {
  padding-top: 1rem; }

nav a, .meta a, h1 a, .copyright a, nav a:visited, .meta a:visited, h1 a:visited, .copyright a:visited {
  color: #000;
  text-decoration: none; }

nav a:hover, .meta a:hover, h1 a:hover {
  color: #362cb2; }

nav a:visited:hover, .meta a:visited:hover, h1 a:visited:hover {
  color: #a60003; }

nav form, nav fieldset {
  margin: 0;
  padding: 0;
  display: inline; }

nav ul {
  text-align: center;
  margin-top: 0; }

nav ul li, nav ul input {
  display: inline-block;
  font-size: 2.3rem; }

nav ul li + li {
  margin-left: 1.7rem; }

nav input {
  border: none;
  width: 7.1rem;
  height: 2.6rem;
  border-radius: 0.5rem;
  margin: 0;
  padding: 0;
  background-color: transparent; }

input.archive {
  width: 100%;
  font-size: 3rem;
  border: 2px solid #76409d;
  padding: 0.5rem; }

::-webkit-input-placeholder {
  /* WebKit browsers */
  color: #000; }

input.archive::-webkit-input-placeholder {
  /* WebKit browsers */
  color: #999; }

:focus::-webkit-input-placeholder {
  color: #999 !important; }

:hover::-webkit-input-placeholder {
  color: #362cb2; }

:-moz-placeholder {
  /* Mozilla Firefox 4 to 18 */
  color: #000;
  opacity: 1; }

input.archive:-moz-placeholder {
  /* Mozilla Firefox 4 to 18 */
  color: #999;
  opacity: 1; }

:focus:-moz-placeholder {
  color: #999 !important; }

:hover:-moz-placeholder {
  color: #362cb2; }

::-moz-placeholder {
  /* Mozilla Firefox 19+ */
  color: #000;
  opacity: 1; }

input.archive::-moz-placeholder {
  /* Mozilla Firefox 19+ */
  color: #999;
  opacity: 1; }

:focus::-moz-placeholder {
  color: #999 !important; }

:hover::-moz-placeholder {
  color: #362cb2; }

:-ms-input-placeholder {
  /* Internet Explorer 10+ */
  color: #000; }

input.archive:-ms-input-placeholder {
  /* Internet Explorer 10+ */
  color: #999; }

:focus:-ms-input-placeholder {
  color: #999 !important; }

:hover:-ms-input-placeholder {
  color: #362cb2; }

form#membership_form_id {
  width: 47rem;
  margin: 6rem auto;
  text-align: center;
  padding: 1rem 5rem 3rem 5rem;
  border: 1px solid #76409d; }

form#membership_form_id fieldset {
  text-align: left; }

form#membership_form_id input {
  font-size: 2.2rem; }

form#membership_form_id .field-row {
  display: block;
  margin: 3rem auto; }

#custom_price {
  width: 6rem;
  border: 3px solid #76409d;
  padding: 0.2rem 0.4rem;
  margin-left: 0.3rem; }

#newsletter_check {
  margin: 4rem auto 3rem auto; }

#submit_container {
  text-align: center; }

#submit_button {
  border: 3px solid #76409d;
  border-radius: 1rem;
  background-color: #fff;
  padding: 0.5rem 1.5rem;
  font-weight: bold; }

#submit_button:active {
  color: #a60003;
  background-color: #f8f8f8;
  border-color: #a60003; }

.membership-plan {
  font-weight: bold;
  margin-right: 1rem;
  display: inline-block;
  width: 13.5rem; }

.membership-plan:after {
  content: ""; }

.regular-plan, .plus-plan, .custom-plan {
  font-weight: bold; }

.regular-plan {
  color: #2F7AFF; }

.plus-plan {
  color: #F12E5B; }

.custom-plan {
  color: #1A8D34; }

.membership-price, #custom_price {
  color: #362cb2;
  font-weight: bold; }

.multipage.paging {
  max-width: 75rem;
  margin: 7rem auto;
  text-align: center; }

.multipage.paging ul {
  display: inline;
  background-color: transparent;
  padding: 1rem;
  border: 0.2rem solid #76409d;
  line-height: 4.5rem;
  white-space: nowrap;
  border-radius: 1.0rem;
  box-decoration-break: clone; }

.multipage.paging ul li {
  display: inline-block;
  list-style-type: none;
  margin: 0.5rem 1rem;
  padding: 0; }

.multipage.paging ul li.paging-collated {
  margin-left: 3rem; }

.multipage.paging a {
  text-decoration: none; }

.multipage.paging ul li a:hover {
  background-color: white; }

.multipage.pagebreak hr {
  border: 2px solid #76409d;
  height: 1px;
  margin: 10rem auto; }

#content article .entry-content p.next_page_link {
  font-weight: bold;
  margin-top: 8rem !important; }

div.highlight, figure.highlight {
  overflow: scroll; }

body header h1 {
  font-size: 7.2rem;
  font-weight: normal;
  letter-spacing: -0.2rem;
  margin: 0; }

#book-banner {
  text-align: center;
  padding: 1.5rem 0.5rem;
  background-color: #76409d;
  font-size: 2.2rem;
  margin-top: 4rem; }

#book-hero-banner {
  padding: 3.0rem 3.5rem;
  font-size: 2.2rem;
  width: 88rem;
  height: 44rem;
  border: 0.2rem solid #ccc;
  position: absolute;
  top: 17rem;
  left: calc(50vw - 44rem);
  background-color: rgba(0, 0, 0, 0.5);
  font-family: Futura-Medium, HelveticaNeue, Arial, sans-serif;
  color: white; }
  #book-hero-banner #book-banner-cover-image {
    display: inline-block;
    float: left;
    width: 23.4rem;
    height: 37.1rem;
    margin-right: 2.5rem;
    border: 0.1rem solid #fff;
    background-image: url("/images/changer-cover-234.jpg");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: 100% 100%; }
    @media only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2 / 1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
      #book-hero-banner #book-banner-cover-image {
        background-image: url("/images/changer-cover-234@2x.jpg"); } }
  #book-hero-banner .book-title {
    display: inline-block;
    font-size: 8rem;
    letter-spacing: 2rem;
    color: #d5a5fa;
    float: left; }
  #book-hero-banner .book-blurb {
    display: inline-block;
    color: white;
    float: left;
    max-width: 45rem; }
    #book-hero-banner .book-blurb a {
      color: white; }
    #book-hero-banner .book-blurb p {
      margin-top: 2.8rem; }
    #book-hero-banner .book-blurb .synopsis {
      font-size: 2.5rem;
      line-height: 2.8rem; }
    #book-hero-banner .book-blurb .review {
      color: #d5a5fa;
      font-style: italic;
      font-size: 2.5rem;
      line-height: 2.8rem; }
    #book-hero-banner .book-blurb .info-button a {
      display: inline-block;
      text-decoration: none;
      border-radius: 1rem;
      border: 0.2rem solid #ccc;
      background-color: #754398;
      padding: 1rem 2rem; }
    #book-hero-banner .book-blurb .info-button a:hover {
      background-color: #d5a5fa;
      border-color: #fff;
      color: black; }

#cover-scroll-marker {
  width: 3rem;
  height: 3rem;
  position: absolute;
  top: calc(100vh - 3rem - 2rem);
  right: 2rem;
  color: white; }
  #cover-scroll-marker:before {
    content: "\25be";
    font-size: 5rem; }

@media only screen and (min-width: 320px) and (max-width: 568px), only screen and (min-width: 320px) and (max-width: 480px) {
  #book-hero-banner {
    background-color: transparent;
    border: none;
    text-align: center;
    padding-top: 6rem; }
    #book-hero-banner #book-banner-cover-image {
      float: none;
      height: 60vh;
      width: calc((23.4 / 37.1) * 60vh);
      margin-top: 0vh;
      border-width: 0.3rem; }
    #book-hero-banner .book-title {
      float: none;
      font-size: 7vh;
      margin: 3rem auto 0 auto;
      color: white; }
    #book-hero-banner .book-blurb {
      display: none; } }
@media only screen and (max-height: 320px) and (max-width: 568px) {
  #book-hero-banner {
    top: 20rem; }
    #book-hero-banner #book-banner-cover-image {
      float: none;
      height: 60vh;
      width: calc((23.4 / 37.1) * 60vh);
      margin-top: 0;
      border-width: 0.3rem; }
    #book-hero-banner .book-title {
      display: none; } }
@media only screen and (min-height: 375px) and (max-height: 414px) {
  #book-hero-banner {
    width: 70rem;
    top: 14rem;
    left: calc(50vw - 35rem);
    margin: 0;
    padding: 0;
    border: none;
    background-color: transparent;
    text-align: center; }
    #book-hero-banner #book-banner-cover-image {
      float: none;
      height: 60vh;
      width: calc((23.4 / 37.1) * 60vh);
      margin: 0;
      border-width: 0.1rem; }
    #book-hero-banner .book-title {
      display: none; }
    #book-hero-banner .book-blurb {
      display: none; } }
@media only screen and (min-width: 760px) and (max-width: 768px) {
  #book-hero-banner {
    width: 65rem;
    left: calc(50vw - 32.5rem); }
    #book-hero-banner .book-title {
      font-size: 3rem; }
    #book-hero-banner .book-blurb {
      max-width: 29rem; } }
#book-banner, #book-banner a, #book-banner a:link, #book-banner a:visited, #book-banner a:active, #book-banner a:hover {
  color: #fff; }

#book-banner img {
  border: 1px solid #fff;
  background-size: 20px 20px; }

#book-banner-cover-image {
  display: inline-block;
  width: 94px;
  height: 149px;
  margin-right: 2rem;
  border: 1px solid #fff;
  background-image: url("/images/changer-cover-94.jpg");
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 94px 149px; }
  @media only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2 / 1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
    #book-banner-cover-image {
      background-image: url("/images/changer-cover-94@2x.jpg"); } }

.book-blurb {
  display: inline-block;
  width: 100%;
  max-width: 40rem;
  vertical-align: top; }

.book-blurb p {
  text-align: left;
  margin: 0; }

.book-blurb p + p {
  margin-top: 1.8rem; }

.synopsis {
  font-size: 2.2rem; }

p.centered {
  text-align: center; }

#book-banner img {
  margin: 0 2rem 0 0; }

#content {
  padding-bottom: 1rem; }

article {
  margin-top: 15rem; }

article.brief {
  margin-top: 5rem; }

#book-banner ~ #content article {
  margin-top: 5rem; }

article header {
  margin-bottom: 11rem; }

article header .meta {
  margin: 4rem 0; }

article.archive header .meta {
  margin: 1rem 0; }

header .meta, header .meta a, header .meta a:hover {
  font-size: 1.9rem;
  color: #666; }

.reading-time-container:before, .post-categories:before {
  content: "\00a0\2022\00a0";
  color: inherit; }

.reading-word-count {
  display: none; }

.reading-time {
  position: relative;
  cursor: help; }

.reading-time:hover .reading-word-count {
  position: absolute;
  top: -0.3rem;
  left: 100%;
  display: inline;
  width: auto;
  height: auto;
  text-align: center;
  color: #000;
  padding: 0.4rem 0.6rem;
  margin: 0 0 0 0.7rem;
  background-color: #eee;
  border-radius: 0.4rem;
  white-space: nowrap; }

article header h1 {
  font-size: 5rem;
  letter-spacing: -0.1rem;
  margin: 0 auto;
  width: 75rem;
  max-width: 95%; }

article header h1.sponsor a {
  color: #555 !important;
  font-size: 3.5rem; }

article header h2 {
  margin-top: 3rem;
  font-style: italic; }

p, ul, ol, blockquote, img {
  margin: 3rem 0; }

article footer, .entry-content > *, #footer-wrapper, article.index .excerpt-link, .prev-next-post-links.index, .briefly-explanation, .home-section-container {
  width: 75rem;
  margin: 3rem auto;
  line-height: 3.5rem; }

.home-section-container {
  margin: 0rem auto 7rem auto;
  padding: 0 3rem; }
  .home-section-container h1 {
    font-size: 3.5rem; }
  .home-section-container:last-child {
    margin-bottom: 20rem; }
  .home-section-container + .home-section-container {
    border-top: 0.3rem solid #76409d;
    padding-top: 7rem; }
  .home-section-container article {
    margin: 0; }
    .home-section-container article header {
      margin: 0; }
      .home-section-container article header h2 {
        border: none;
        margin: 0;
        font-style: normal;
        font-size: 2.5rem; }
    .home-section-container article + article {
      margin-top: 2rem; }
    .home-section-container article .entry-content {
      font-style: italic; }
  .home-section-container .all-articles-link {
    margin-top: 5rem; }

@media only screen and (min-width: 320px) and (max-width: 568px), only screen and (min-width: 320px) and (max-width: 480px) {
  .home-section-container {
    width: 80%; }
    .home-section-container h1 {
      font-size: 6rem;
      margin-bottom: 6rem; }
    .home-section-container p {
      font-size: 4.5rem;
      line-height: 6.5rem; }
    .home-section-container article header h2 {
      font-size: 5rem;
      line-height: 6.5rem; }
    .home-section-container article .entry-content {
      font-style: normal;
      font-size: 4rem;
      line-height: 6rem; }
    .home-section-container article + article {
      margin-top: 6rem; }
    .home-section-container .all-articles-link {
      margin-top: 8rem; } }
@media only screen and (min-height: 375px) and (max-height: 414px) {
  .home-section-container {
    width: 80%; } }
@media only screen and (min-height: 370px) and (max-height: 375px) {
  #wrapper {
    overflow: hidden; } }
#footer-wrapper {
  margin: 0 auto; }

#footer-wrapper > * {
  margin-top: 2rem; }

.entry-content > h1, .entry-content > h2, .entry-content > h3, .entry-content > h4, .entry-content > h5, .entry-content > h6 {
  font-size: 2.5rem;
  font-weight: bold;
  letter-spacing: -0.1rem;
  margin: 6rem auto 3rem auto; }

.entry-content > h2 {
  font-size: 3rem;
  margin-top: 8rem; }

.entry-content > hr {
  border: 0;
  height: 1px;
  background: #999;
  margin: 5rem auto; }

body #wrapper {
  margin: 0 !important; }

p.full-width, p.full-width-centered {
  width: 100%;
  text-align: center; }

p.full-width-centered {
  background-color: #333;
  padding: 0.1rem 0;
  margin-top: 6rem; }

img.full-width {
  display: block;
  width: 100%;
  max-width: 1600px;
  margin: 6rem auto;
  height: auto; }

img.full-width-centered {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto; }

.full-width + .caption, .full-width-centered + .caption {
  text-align: center;
  font-style: italic;
  margin-top: -2.5rem;
  margin-bottom: 6rem; }

.caption + .full-width-centered {
  margin-top: 10rem; }

.heading-banner, .cover-banner {
  width: 100%;
  height: 230px;
  overflow: hidden;
  position: absolute;
  top: 16.3rem;
  margin: 0 auto;
  z-index: -100;
  background-repeat: no-repeat;
  background-attachment: scroll;
  background-position: center;
  background-size: cover; }

.cover-banner {
  z-index: 0;
  position: relative;
  padding: 0;
  top: -29.4rem;
  height: 100vh;
  /* vh means hundredths of viewport height */
  max-height: 1067px;
  overflow: visible; }

#cover-shield {
  margin: 0 auto;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 0;
  position: relative;
  padding: 0;
  height: 100vh;
  /* vh means hundredths of viewport height */
  overflow: visible; }

#wrapper > .cover-banner {
  position: absolute;
  top: 0; }

#wrapper > #cover-shield {
  position: absolute;
  top: 0; }

#wrapper > .cover-banner ~ #content {
  margin-top: 100vh; }

.cover-banner > h1 {
  font-size: 9rem;
  position: relative;
  top: calc(50% - (9rem / 2));
  margin: 0;
  padding: 1rem 0;
  width: 100%;
  max-width: 100%; }

.cover-banner h2 {
  font-size: 4rem;
  font-style: italic;
  position: relative;
  top: calc(100% - (11rem + 6rem + 1rem));
  margin: 0;
  padding: 1rem 0;
  width: 100%;
  max-width: 100%; }

.cover-banner > .meta {
  position: relative;
  margin: 0;
  top: calc(100% - 11rem + 2.1rem); }

.cover-banner > h2 + .meta {
  top: calc(100% - 11rem - 6rem + 2.1rem); }

.cover-banner + .entry-content {
  margin-top: -17rem; }

.entry-content > .screenshot img {
  width: auto;
  height: auto;
  margin: 0;
  position: static;
  border: 1px solid #999; }

.entry-content > .screenshot {
  text-align: center;
  margin: 5rem auto; }

.entry-content > .screenshot p.caption {
  font-size: 2.2rem;
  color: #333;
  border: 1px solid #ddd;
  text-align: center;
  background-color: #fafafa;
  padding: 0.5rem 0.8rem;
  margin: 1rem;
  -moz-border-radius: 0.3rem;
  -khtml-border-radius: 0.3rem;
  -webkit-border-radius: 0.3rem;
  border-radius: 0.3rem; }

.mono, pre, code, tt, p code, li code {
  font-family: Menlo, Monaco, "Andale Mono", "Lucida Console", "Courier New", monospace;
  display: inline-block;
  white-space: no-wrap;
  font-size: 2rem;
  color: #333;
  background: #eeeeee;
  border: none;
  padding: 0 0.5rem; }

.entry-content > blockquote {
  padding: 1rem 2rem 0.5rem 1rem;
  font-size: 2.6rem;
  font-style: oblique;
  background-color: #f5f5f5;
  margin: 5rem auto; }

blockquote:before, blockquote:after {
  font-style: normal;
  content: "\201C";
  display: block;
  font-size: 7rem;
  color: #aaa;
  padding: 0;
  line-height: 0rem;
  background-color: inherit;
  width: 100%;
  margin: 3.2rem 0 0 0.5rem; }

blockquote:after {
  content: "\201D";
  text-align: right;
  margin: 0;
  margin-top: 3rem; }

blockquote p {
  margin: 0 4rem; }

blockquote p + p {
  margin-top: 2.5rem; }

blockquote em {
  font-weight: bold; }

blockquote.example {
  font-style: inherit;
  text-decoration: none;
  background-color: #f5f5f5;
  padding: 20px 25px !important;
  border: 2px solid #999;
  white-space: pre-wrap; }

blockquote.example:before, blockquote.example:after {
  content: ""; }

blockquote.example em {
  font-weight: normal; }

blockquote.example.flawed {
  border-color: #a60003; }

blockquote.example.flawed:after {
  content: "\2718";
  font-size: 5rem;
  color: rgba(166, 0, 3, 0.7);
  padding-bottom: 1.5rem; }

blockquote.example.fixed {
  border-color: #76409d; }

blockquote.example.fixed:after {
  content: "\2714";
  color: rgba(118, 64, 157, 0.7);
  padding-bottom: 1.5rem; }

span.platform {
  font-weight: 500;
  font-family: "Helvetica Neue", sans-serif;
  border: 0.3rem solid transparent;
  padding: 0 0.5rem;
  border-radius: 1rem;
  background-color: transparent;
  white-space: nowrap; }

span.ios {
  color: #0080FF;
  border-color: #0080FF; }

span.windows-phone {
  color: #55AC02;
  border-color: #55AC02;
  border-radius: 0; }

span.android {
  color: #BF1911;
  border-color: #BF1911;
  border-radius: 1rem 0 1rem 0; }

.entry-content > ul, .entry-content > ol {
  margin: 4rem auto; }

article ul li, article ol li {
  margin: 2rem 0 2rem 2.9rem; }

article ul li {
  list-style-type: disc; }

article ol li {
  list-style-type: decimal; }

article footer {
  margin: 15rem auto;
  border-top: 0.6rem solid #76409d; }

blockquote > footer {
  margin: 2rem 4rem 0 4rem;
  border: none; }

article.index + article {
  margin-top: 5rem; }

article.index + article header h1 {
  padding-top: 10rem;
  border-top: 0.3rem solid #76409d; }

article.archive header {
  margin: 2rem auto;
  text-align: left; }

article.archive header h1 {
  font-size: 4rem;
  line-height: 4.5rem;
  margin: 0 0 1rem 0;
  text-align: left;
  max-width: 100%; }

article.archive header h1 {
  padding-top: 5rem;
  border-top: 0.3rem solid #76409d; }

article.archive header time {
  font-size: 2rem;
  color: #737373; }

article.archive .entry-content {
  color: #000; }

.entry-content.brief > p:first-child:first-letter {
  float: left;
  padding-top: 0.7rem;
  padding-right: 0.2rem;
  font-size: 7.5rem;
  line-height: 6rem;
  color: #76409d;
  text-transform: uppercase; }
.entry-content.brief > p:last-child:after {
  content: "MG";
  color: #76409d;
  padding-left: 0.8rem;
  font-weight: bold;
  font-size: 2rem; }

.briefly-explanation a {
  display: block;
  font-style: italic;
  color: #999;
  text-decoration: none;
  text-align: center;
  font-size: 2rem; }
  .briefly-explanation a:before, .briefly-explanation a:after {
    content: "\00a0\2014\00a0"; }

article header time a {
  color: inherit !important; }

article header time a:hover {
  text-decoration: underline; }

.prev-next-post-links.index {
  margin: 9rem auto 11rem auto; }

article.page {
  margin-bottom: 20rem; }

.sharing {
  margin: 1rem 0;
  text-align: center; }

.sharing-button, .sharing-button:visited {
  display: inline-block;
  text-align: center;
  width: 18.3rem;
  min-width: 10rem;
  background-color: #ccc;
  color: #fff;
  text-decoration: none;
  margin-bottom: 0.5rem; }

.sharing-button.twitter {
  background-color: #00aced; }

.sharing-button.twitter:hover {
  background-color: #009bd4; }

.sharing-button.facebook {
  background-color: #3B5998; }

.sharing-button.facebook:hover {
  background-color: #223683; }

.sharing-button.googleplus {
  background-color: #d34836; }

.sharing-button.googleplus:hover {
  background-color: #bd0000; }

.sharing-button.email {
  background-color: #777; }

.sharing-button.email:hover {
  background-color: #666; }

footer .sponsor, footer .patronage, div.footnotes {
  text-align: center;
  font-style: oblique;
  margin: 5rem 0 5rem 0;
  padding: 0.5rem;
  background-color: #eee; }

div.footnotes {
  text-align: left;
  margin: 10rem auto; }

footer .patronage {
  margin: 5rem 0 10rem 0; }

footer .patronage + .sponsor {
  margin-top: -9rem; }

.prev-next-post-links {
  height: 5rem;
  text-align: center; }

.prev-post {
  float: left; }

.next-post {
  float: right; }

.post-categories {
  display: inline; }

.category-link {
  text-decoration: none;
  color: inherit !important; }

.category-link:hover {
  text-decoration: underline; }

.flag {
  color: #dd0000 !important; }

p.flag:before {
  content: "\26a0\00a0"; }

.category-link.flag {
  border: 0.2rem solid #dd0000;
  border-radius: 2.2rem;
  padding: 0.1rem 0.6rem; }

#wrapper > footer {
  border-top: 0.6rem solid #76409d;
  margin-top: 25rem;
  width: 100%;
  height: 8.3rem;
  position: absolute;
  bottom: 0;
  left: 0; }

#wrapper > footer .copyright {
  float: left; }

.copyright a {
  text-decoration: none; }

#wrapper > footer ul {
  float: right; }

#wrapper > footer ul li {
  display: inline-block; }

#wrapper > footer ul li + li {
  margin-left: 1rem; }

.note-popover {
  cursor: help;
  color: #000;
  text-decoration: none;
  border-bottom: 2px dashed #e1b509; }

.note-popover:hover, .note-popover:active {
  background-color: #fcf4dd; }

.note-popover:hover:after, .note-popover:active:after {
  border-radius: 0.8rem;
  border: 2px solid #e1b509;
  background-color: #fcf4dd;
  content: attr(data-note);
  padding: 0.4rem 1rem;
  margin: 0.6rem auto;
  white-space: pre-line;
  position: relative;
  display: block;
  width: auto; }

.keyboard-shortcut {
  color: #2076c8;
  font-size: 100%;
  font-weight: normal;
  font-family: Helvetica, sans-serif;
  border-radius: 0.4em;
  border: 1px solid #999;
  background-color: #f9f9f9;
  display: inline-block;
  padding: 0px 5px;
  margin: 0 3px; }

a.download {
  display: inline-block;
  border-radius: 0.4em;
  border: 2px solid #362cb2;
  background-color: #f9f9f9;
  padding: 25px 10px 25px 65px; }
  a.download:visited {
    border-color: #a60003; }
  a.download:active {
    border-color: #362cb2; }
  a.download:before {
    content: ""; }
  a.download.zip, a.download.pdf {
    background-image: url("/images/zip.png");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: 64px 64px; }
    @media only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2 / 1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
      a.download.zip, a.download.pdf {
        background-image: url("/images/zip@2x.png"); } }
  a.download.pdf {
    background-image: url("/images/pdf.png"); }
    @media only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2 / 1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
      a.download.pdf {
        background-image: url("/images/pdf@2x.png"); } }

#fusion_ads_container {
  display: block;
  width: 200px;
  position: absolute;
  top: 330px;
  right: 0px;
  text-align: center;
  margin: 0; }

.fusionentire, .fusion_attrib_footer {
  display: block;
  width: 200px;
  padding: 0;
  margin: 0 auto; }

.fusionentire {
  margin: 0 auto 0 auto; }

.fusionentire, .fusion_attrib_footer, .fusiontext {
  font-size: 1.2rem;
  line-height: 1.5rem;
  text-align: center; }

.fusiontext {
  margin: 0; }

.fusiontext, .fusion_attrib_footer {
  font-family: Helvetica, Verdana, sans-serif; }

.fusiontext, .fusiontext a {
  color: #000; }

.fusionimg {
  text-align: center;
  border: 0;
  margin: 0 auto 1rem auto;
  display: inline; }

.fusionimg a {
  border: 0; }

.fusion_attrib_footer {
  margin: 1rem auto 0 auto;
  font-size: 1.1rem;
  border: none; }

.bsap {
  display: none; }

.fusion_attrib_footer a {
  color: #999; }

.fusionentire a, .fusion_attrib_footer a {
  text-decoration: none;
  border: none; }

.mobile-nav {
  display: none; }

.multipage-paging-mobile {
  display: block;
  text-align: center;
  margin-top: 2rem;
  margin-bottom: 2rem; }

.multipage-paging-mobile select {
  width: 95%;
  font-size: 2rem;
  -webkit-appearance: button;
  -webkit-padding-start: 2px;
  -webkit-padding-end: 20px;
  -webkit-user-select: none;
  border-radius: 1rem;
  border: 0.3rem solid #76409d;
  background-color: #fff;
  color: #362cb2;
  margin: 0px;
  overflow: hidden;
  padding: 5px 10px;
  text-overflow: ellipsis;
  white-space: nowrap; }

.multipage-paging-mobile {
  display: block;
  width: 100%; }

.multipage-paging-mobile select {
  display: inline;
  width: 80%;
  margin: auto 0.3rem; }

.multipage ul.multipage-paging-links {
  display: none; }

input[type=checkbox].section_toggle + label + div {
  display: none;
  visibility: hidden; }

input[type=checkbox].section_toggle {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute; }

.collapsible_section {
  border: 0.2rem solid #1b99d3;
  border-radius: 1rem;
  overflow: hidden;
  margin: 0 auto; }

.collapsible_content {
  padding: 2rem;
  max-height: 55rem;
  overflow: scroll; }

.collapsible_content p {
  margin: 0; }

.collapsible_content p + p {
  margin-top: 2rem; }

.collapsible_content .attribution {
  display: block;
  font-style: italic;
  text-align: right; }

.collapsible_content .attribution:before {
  content: "\2014\00a0"; }

.attribution .twitter_username {
  color: #666; }

.attribution .twitter_username:before {
  content: "\00a0("; }

.attribution .twitter_username:after {
  content: ")"; }

.collapsible_section label {
  display: block;
  padding: 0.6rem;
  padding-left: 1.5rem;
  cursor: pointer;
  height: 5rem; }

.collapsible_section label:before {
  content: "\25BE\00a0";
  color: #1b99d3;
  padding-right: 0; }

input[type=checkbox].section_toggle:checked + label:before {
  content: "\00d7\00a0";
  padding-right: 0; }

.collapsible_section + .collapsible_section {
  margin-top: 3rem; }

input[type=checkbox].section_toggle:checked + label {
  background-color: #eee; }

.collapsible_section label:hover, input[type=checkbox].section_toggle:checked + label:hover {
  background-color: #eee; }

input[type=checkbox].section_toggle:checked + label {
  border-bottom: 0.2rem solid #1b99d3; }

input[type=checkbox].section_toggle:checked + label ~ div.collapsible_content {
  display: block;
  visibility: visible; }

@media only screen and (max-width: 1060px) {
  #fusion_ads_container {
    position: relative;
    display: inline-block;
    width: 200px;
    top: 0;
    left: calc(50% - 100px);
    margin: 2rem auto; } }
@media only screen and (max-width: 790px) {
  #fusion_ads_container {
    display: none; } }
@media only screen and (max-width: 785px) {
  article footer, .entry-content > *, #footer-wrapper, article.index .excerpt-link, .prev-next-post-links.index, article header h1, .briefly-explanation {
    width: 95%; }

  #wrapper > header h1 {
    font-size: 6.2rem; }

  body header {
    padding-top: 1rem; }

  nav ul li, nav ul input {
    font-size: 2rem; }

  nav ul li + li {
    margin-left: 1rem; }

  article {
    margin-top: 6rem; }

  article header {
    margin-bottom: 6rem; }

  .sharing-button {
    width: 49%;
    min-width: 20rem; }

  .prev-post, .next-post {
    float: none;
    display: block;
    margin-top: 3rem; }

  #wrapper footer {
    text-align: center; }

  #wrapper footer .copyright, #wrapper footer ul.meta {
    float: none; }

  #wrapper footer ul.meta {
    padding-bottom: 2rem; }

  .prev-next-post-links {
    height: 10rem; }

  .heading-banner {
    top: 130px;
    height: 120px;
    background-size: cover; } }
@media only screen and (max-width: 430px) {
  nav ul li, nav ul input {
    font-size: 1.7rem; } }
/* iPads */
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  img {
    max-width: 100%; }

  article footer, .entry-content > *, #footer-wrapper, article.index .excerpt-link, .prev-next-post-links.index, article header h1, .briefly-explanation {
    width: 75%; }

  #wrapper > header h1 {
    font-size: 6.2rem; }

  body header {
    padding-top: 1rem; }

  nav ul li, nav ul input {
    font-size: 2rem; }

  nav ul li + li {
    margin-left: 1rem; }

  article {
    margin-top: 6rem; }

  article header {
    margin-bottom: 6rem; }

  article .entry-content > * {
    margin: 4rem auto;
    font-size: 2rem;
    line-height: 3.7rem; }

  article ul li, article ol li {
    margin-left: 4rem; }

  .entry-content h2 {
    font-size: 4rem;
    margin-top: 6rem; }

  .entry-content h3, .entry-content h4 {
    font-size: 3rem; }

  .sharing-button {
    width: 24%;
    min-width: 20rem;
    font-size: 2.6rem;
    line-height: 4rem; }

  .prev-post, .next-post {
    float: none;
    display: block;
    margin-top: 4rem; }

  #wrapper footer {
    text-align: center; }

  #wrapper footer .copyright, #wrapper footer ul.meta {
    float: none;
    font-size: 2rem; }

  #wrapper footer ul.meta {
    padding-bottom: 2rem; }

  .prev-next-post-links {
    height: 10rem; }

  footer .sponsor, footer .patronage {
    font-size: 2.5rem;
    line-height: 3.5rem; }

  #fusion_ads_container {
    display: none; }

  .heading-banner {
    top: 130px;
    height: 120px;
    background-size: cover; }

  .cover-banner {
    max-height: 100vh;
    top: -173px; }

  .cover-banner > h1 {
    font-size: 7rem; }

  .cover-banner > .meta {
    top: calc(100% - 11rem + 4.1rem); }

  .cover-banner + .entry-content {
    margin-top: -11rem; }

  form#membership_form_id {
    font-size: 2.2rem; }

  .collapsible_section label:before {
    padding-right: 0.3rem; } }
/* iPhones */
@media only screen and (min-width: 320px) and (max-width: 568px), only screen and (min-width: 320px) and (max-width: 480px) {
  html {
    font-size: 4px; }

  img {
    max-width: 100%; }

  #book-banner, .synopsis {
    font-size: 3.5rem; }

  #book-banner img {
    max-height: 100px; }

  .book-blurb {
    width: 90%; }

  article.archive header h1 {
    font-size: 5.5rem;
    line-height: 5.5rem; }

  article.archive header time {
    font-size: 3rem; }

  article.archive .entry-content {
    font-size: 4rem; }

  article footer, .entry-content > *, #footer-wrapper, article.index .excerpt-link, .prev-next-post-links.index, article header h1, .briefly-explanation {
    width: 90%; }

  #wrapper > header h1 {
    font-size: 7rem;
    line-height: 8rem; }

  .mobile-nav, .multipage-paging-mobile {
    display: block;
    text-align: center;
    margin-top: 2rem;
    margin-bottom: 2rem; }

  .mobile-nav select, .multipage-paging-mobile select {
    width: 95%;
    font-size: 4rem;
    -webkit-appearance: button;
    -webkit-padding-start: 2px;
    -webkit-padding-end: 20px;
    -webkit-user-select: none;
    border-radius: 3px;
    border: 1px solid #76409d;
    background-color: #fff;
    color: #362cb2;
    margin: 0px;
    overflow: hidden;
    padding: 5px 10px;
    text-overflow: ellipsis;
    white-space: nowrap; }

  .multipage-paging-mobile {
    display: block;
    width: 100%; }

  .multipage-paging-mobile select {
    display: inline;
    width: 80%;
    margin: auto 0.3rem; }

  #wrapper nav {
    height: 11.5rem; }

  .main-navigation, .multipage ul.multipage-paging-links {
    display: none; }

  article header h1 {
    font-size: 7rem; }

  article {
    margin-top: 6rem; }

  article header {
    margin-bottom: 6rem; }

  article .entry-content > * {
    line-height: 6.5rem;
    margin: 7rem auto; }

  article .entry-content > div iframe {
    margin: 3rem auto;
    max-width: 100%; }

  article header .meta {
    margin-top: 2.5rem; }

  article header .meta > *, article header .meta .reading-time, article header .meta .post-categories a, article header .meta time a {
    font-size: 3rem; }

  body #wrapper, .entry-content blockquote {
    font-size: 5rem; }

  .entry-content code {
    font-size: 4rem; }

  .entry-content h2 {
    font-size: 6rem;
    margin-top: 10rem; }

  .entry-content h3, .entry-content h4 {
    font-size: 5rem; }

  article ul li, article ol li {
    margin: 7rem 0 7rem 6rem; }

  .note-popover {
    border-bottom: 3px dashed #e1b509; }

  .sharing-button {
    width: 49%;
    min-width: 30rem;
    font-size: 5rem;
    line-height: 7rem; }

  .prev-next-post-links {
    height: 13rem;
    text-align: center; }

  .prev-post, .next-post {
    margin-top: 5rem;
    float: none;
    display: block; }

  footer .sponsor, footer .patronage {
    font-size: 4rem;
    line-height: 6rem; }

  #wrapper footer {
    text-align: center; }

  #wrapper footer ul.meta {
    padding-bottom: 5rem; }

  #wrapper footer .copyright, #wrapper footer ul.meta {
    font-size: 4rem;
    float: none;
    display: block; }

  #fusion_ads_container {
    display: none; }

  .heading-banner {
    top: 83px;
    height: 60px; }

  .category-link.flag {
    border-width: 0.25rem;
    border-radius: 3.5rem;
    padding: 0.1rem 1rem; }

  .cover-banner {
    max-height: 100vh;
    top: -109px; }

  form#membership_form_id {
    font-size: 3.5rem;
    width: 67rem; }

  form#membership_form_id input {
    font-size: 4rem; }

  form#membership_form_id .field-row {
    margin: 5rem auto; }

  #custom_price {
    width: 8rem; }

  .membership-plan {
    width: 20rem; }

  span.platform {
    border-width: 0.6rem;
    font-size: 4rem; }

  span.ios {
    border-radius: 2rem; }

  span.android {
    border-radius: 2rem 0 2rem 0; }

  .collapsible_section label {
    height: 9rem;
    font-size: 5rem;
    padding: 1rem;
    padding-left: 3rem; }

  .collapsible_section label:before {
    padding-right: 0.9rem; }

  input[type=checkbox].section_toggle:checked + label, .collapsible_section {
    border-width: 0.4rem; }

  .collapsible_section {
    border-radius: 2rem; }

  .collapsible_section label:hover, input[type=checkbox].section_toggle:checked + label:hover, input[type=checkbox].section_toggle:checked + label {
    background-color: #fff; }

  .collapsible_content {
    font-size: 5rem; }

  .entry-content.brief > p:first-child:first-letter {
    font-size: 9rem; }
  .entry-content.brief > p:last-child:after {
    padding-left: 1.5rem;
    font-size: 4rem; }

  .briefly-explanation a {
    font-size: 4rem; } }
/**
 * Syntax highlighting styles
 */
.highlight {
  background: #fff; }
  .highlight .c {
    color: #998;
    font-style: italic; }
  .highlight .err {
    color: #a61717;
    background-color: #e3d2d2; }
  .highlight .k {
    font-weight: bold; }
  .highlight .o {
    font-weight: bold; }
  .highlight .cm {
    color: #998;
    font-style: italic; }
  .highlight .cp {
    color: #999;
    font-weight: bold; }
  .highlight .c1 {
    color: #998;
    font-style: italic; }
  .highlight .cs {
    color: #999;
    font-weight: bold;
    font-style: italic; }
  .highlight .gd {
    color: #000;
    background-color: #fdd; }
  .highlight .gd .x {
    color: #000;
    background-color: #faa; }
  .highlight .ge {
    font-style: italic; }
  .highlight .gr {
    color: #a00; }
  .highlight .gh {
    color: #999; }
  .highlight .gi {
    color: #000;
    background-color: #dfd; }
  .highlight .gi .x {
    color: #000;
    background-color: #afa; }
  .highlight .go {
    color: #888; }
  .highlight .gp {
    color: #555; }
  .highlight .gs {
    font-weight: bold; }
  .highlight .gu {
    color: #aaa; }
  .highlight .gt {
    color: #a00; }
  .highlight .kc {
    font-weight: bold; }
  .highlight .kd {
    font-weight: bold; }
  .highlight .kp {
    font-weight: bold; }
  .highlight .kr {
    font-weight: bold; }
  .highlight .kt {
    color: #458;
    font-weight: bold; }
  .highlight .m {
    color: #099; }
  .highlight .s {
    color: #d14; }
  .highlight .na {
    color: #008080; }
  .highlight .nb {
    color: #0086B3; }
  .highlight .nc {
    color: #458;
    font-weight: bold; }
  .highlight .no {
    color: #008080; }
  .highlight .ni {
    color: #800080; }
  .highlight .ne {
    color: #900;
    font-weight: bold; }
  .highlight .nf {
    color: #900;
    font-weight: bold; }
  .highlight .nn {
    color: #555; }
  .highlight .nt {
    color: #000080; }
  .highlight .nv {
    color: #008080; }
  .highlight .ow {
    font-weight: bold; }
  .highlight .w {
    color: #bbb; }
  .highlight .mf {
    color: #099; }
  .highlight .mh {
    color: #099; }
  .highlight .mi {
    color: #099; }
  .highlight .mo {
    color: #099; }
  .highlight .sb {
    color: #d14; }
  .highlight .sc {
    color: #d14; }
  .highlight .sd {
    color: #d14; }
  .highlight .s2 {
    color: #d14; }
  .highlight .se {
    color: #d14; }
  .highlight .sh {
    color: #d14; }
  .highlight .si {
    color: #d14; }
  .highlight .sx {
    color: #d14; }
  .highlight .sr {
    color: #009926; }
  .highlight .s1 {
    color: #d14; }
  .highlight .ss {
    color: #990073; }
  .highlight .bp {
    color: #999; }
  .highlight .vc {
    color: #008080; }
  .highlight .vg {
    color: #008080; }
  .highlight .vi {
    color: #008080; }
  .highlight .il {
    color: #099; }

nav {
  height: 3.6rem; }

nav ul ul {
  padding: 0;
  margin: 0 0 0 0;
  list-style: none;
  position: relative;
  font-size: 0;
  border: 0rem solid #362cb2;
  /* box-shadow: 0 0.5rem 0.8rem rgba(144, 144, 144, 0.8); */
  box-shadow: 0 0.1rem 0.8rem 0.1rem rgba(0, 0, 0, 0.4);
  /*-webkit-filter: drop-shadow(0 0.1rem 0.49rem rgba(0, 0, 0, 0.4));
  filter: drop-shadow(0 0.1rem 0.49rem rgba(0, 0, 0, 0.4));
  -webkit-transform: translateZ(0);*/ }

nav > ul > li > ul {
  margin-top: 1.5rem; }

nav > ul > li > ul:before, nav > ul > li > ul:after {
  content: "";
  display: block;
  position: absolute;
  top: -1.5rem;
  left: 1.4rem;
  width: 0;
  border-width: 0 1.5rem 1.5rem 1.5rem;
  border-style: solid;
  border-color: white transparent; }

nav > ul > li > ul:before {
  top: -1.7rem;
  left: 1.0rem;
  border-width: 0 1.9rem 1.7rem 1.9rem;
  border-color: rgba(0, 0, 0, 0.06) transparent; }

nav ul ul li a {
  background-color: white;
  overflow: hidden; }

nav ul ul {
  border-radius: 0.6rem; }

nav ul ul li:first-child, nav ul ul li:first-child > a,
nav ul ul ul li:first-child, nav ul ul ul li:first-child > a {
  border-top-left-radius: 0.4rem;
  border-top-right-radius: 0.4rem; }

nav ul ul li:last-child, nav ul ul li:last-child > a,
nav ul ul ul li:last-child, nav ul ul ul li:last-child > a {
  border-bottom-left-radius: 0.4rem;
  border-bottom-right-radius: 0.4rem; }

nav ul li {
  display: inline-block;
  text-align: left; }

nav, nav ul li {
  background-color: inherit; }

nav ul ul a {
  display: block;
  padding: 0 1.5rem;
  color: black;
  font-size: 2rem;
  line-height: 6rem;
  text-decoration: none;
  white-space: nowrap; }

nav ul ul li, nav ul ul li a {
  color: black !important; }

.menu-subtitle {
  display: block;
  color: #362cb2;
  font-size: 1.6rem;
  line-height: 3rem;
  font-style: italic;
  margin-top: -1.6rem;
  padding-bottom: 1rem;
  margin-left: 0.5rem; }

.icon .menu-subtitle {
  margin-left: 3.5rem; }

nav a.menu-item-disabled, nav a.menu-item-disabled:hover, nav a.menu-item-disabled:focus,
nav a.menu-item-separator, nav a.menu-item-separator:hover, nav a.menu-item-separator:focus {
  background-color: white !important;
  background-image: none !important;
  color: #777 !important;
  cursor: default; }

.dark-mode ul {
  border-color: white; }
  .dark-mode ul ul {
    border-color: white; }
  .dark-mode ul a {
    color: white !important;
    background-color: rgba(0, 0, 0, 0.8); }
  .dark-mode ul .menu-subtitle {
    color: #9056ba; }
  .dark-mode ul a.menu-item-disabled, .dark-mode ul a.menu-item-disabled:hover, .dark-mode ul a.menu-item-disabled:focus,
  .dark-mode ul a.menu-item-separator, .dark-mode ul a.menu-item-separator:hover, .dark-mode ul a.menu-item-separator:focus {
    background-color: rgba(0, 0, 0, 0.8) !important;
    color: #aaaaaa !important; }
  .dark-mode ul a.menu-item-separator {
    border-color: #666; }
  .dark-mode ul .menu-item-disabled .menu-subtitle {
    color: #aaaaaa !important; }
  .dark-mode ul .new {
    color: #ff3333; }
  .dark-mode ul li > a:after {
    color: white; }

nav > ul.dark-mode > li > ul:after {
  border-color: rgba(0, 0, 0, 0.8) transparent; }

.new {
  color: red; }

.new:before {
  content: '\2605';
  padding-right: 0.6rem;
  font-size: 1.8rem; }

a:hover .menu-subtitle, a:focus .menu-subtitle, .menu-item-disabled .menu-subtitle {
  color: inherit; }

nav a:hover, nav a:focus {
  /* background-color: $brand-color; */ }

nav ul ul a:hover, nav ul ul a:focus {
  background-color: #76409d; }

nav a:hover, nav a:focus, li > a:hover:after, li > a:focus:after {
  color: #362cb2 !important;
  /* white */ }

nav ul ul a:hover, nav ul ul li > a:hover:after,
nav ul ul a:focus, nav ul ul li > a:focus:after {
  color: white !important; }

nav ul a.menu-item-separator {
  /* margin: 3px 0; */
  border-bottom: 0.2rem solid #ddd; }

/* Hide menu by default */
nav ul ul {
  /* display: none; */
  position: absolute;
  z-index: 0;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0s linear 0.2s, opacity 0.1s linear 0.1s; }

/* Display menu on hover */
nav ul li:hover > ul {
  /* display: inherit; */
  z-index: 1;
  visibility: visible;
  opacity: 1;
  transition-delay: 0s; }

/* First-tier menu */
nav ul ul li {
  min-width: 10rem;
  max-width: 35rem;
  display: list-item;
  position: relative; }

nav ul ul li {
  border-bottom: 0.1rem solid #ccc; }

nav > ul ul li + li {
  margin-left: 0; }

ul.no-dividers li {
  border-bottom: none; }

nav ul ul li:last-child {
  border: none; }

/* Second and deeper tiers	*/
nav ul ul ul {
  top: 0;
  left: 100%; }

/* Symbols added to items with sub-menus */
li > a:after {
  /* top level */
  /* content: '\00a0\00a0\25BE'; */
  color: #777; }

nav ul ul li > a:after {
  /* deeper levels */
  content: '\00a0\00a0\00a0\25BA';
  font-size: 1.3rem;
  position: absolute;
  top: 0.1rem;
  right: 1rem; }

li > a:only-child:after {
  /* hide symbol on leaf nodes */
  content: '' !important; }

li ul li > a {
  padding-right: 3.5rem; }

li ul li > a:only-child {
  padding-right: 1.5rem; }

/*
li a.kestrel.changer:link, li a.kestrel.changer:visited {
	color: #6000FF;
}

li a.kestrel.changer:hover, li a.kestrel.changer:focus {
	background-color: #6066FF;
	background-image: linear-gradient(#607EFF, #6000ff);
}
*/
/*
li a.series-1:before {
	content: '\2460';
	padding-right: 0.9rem;
}
*/
li a.updated:before {
  content: '\00a0\25cf';
  padding-right: 1.3rem;
  color: #009AFF;
  font-size: 2.7rem; }

li a.about:before {
  content: '\2139';
  padding-left: 0.3rem;
  padding-right: 0.6rem;
  color: #009AFF;
  font-size: 3.5rem; }

li a.best:before {
  content: '\2605';
  padding-right: 0.5rem;
  color: #FFBA00;
  font-size: 2.5rem; }

li a.contact:before {
  content: '@';
  padding-right: 0.5rem;
  color: #009aff;
  font-size: 2.5rem; }

ul ul li a:hover:before, ul ul li a:focus:before {
  color: white; }

ul ul li a.menu-item-disabled:hover:before, ul ul li a.menu-item-disabled:focus:before {
  color: inherit; }

@font-face {
  font-family: 'mg-site-icons';
  src: url("/fonts/mg-site-icons.eot");
  src: url("/fonts/mg-site-icons.eot#iefix") format("embedded-opentype"), url("/fonts/mg-site-icons.ttf") format("truetype"), url("/fonts/mg-site-icons.woff") format("woff"), url("/fonts/mg-site-icons.svg#mg-site-icons") format("svg");
  font-weight: normal;
  font-style: normal; }
[class^="site-icon-"]:before, [class*=" site-icon-"]:before {
  font-family: 'mg-site-icons';
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-right: 1.1rem; }

.site-icon-email:before {
  content: "\e600";
  padding-right: 0.8rem; }

.site-icon-rss:before {
  content: "\e601";
  color: #FF8D00; }

.site-icon-rss:hover, .site-icon-rss:focus {
  background-color: #FF7500; }

.site-icon-search:before {
  content: "\e602"; }

.site-icon-twitter:before {
  content: "\e603";
  color: #00aced; }

.site-icon-twitter:hover, .site-icon-twitter:focus {
  background-color: #00aced; }

.site-icon-facebook:before {
  content: "\e604";
  color: #3B5998; }

.site-icon-facebook:hover, .site-icon-facebook:focus {
  background-color: #3B5998; }

.site-icon-googleplus:before {
  content: "\e605";
  color: #d34836; }

.site-icon-googleplus:hover, .site-icon-googleplus:focus {
  background-color: #d34836; }

.contact .site-icon-email:hover, .contact .site-icon-email:focus {
  background-color: #777; }

ul.iconic {
  width: 21.2rem;
  height: 6.3rem; }
  ul.iconic li, ul.iconic a {
    display: inline-block;
    min-width: 0;
    margin: 0;
    height: 6.3rem;
    width: 5.3rem; }
  ul.iconic li, ul.iconic li + li {
    padding: 0;
    margin: 0; }
  ul.iconic a:before {
    padding-right: 0;
    font-size: 2.3rem; }
  ul.iconic .icon-subtitle {
    display: none; }
  ul.iconic li:first-child, ul.iconic li:first-child > a {
    border-top-left-radius: 0.4rem;
    border-bottom-left-radius: 0.4rem;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0; }
  ul.iconic li:last-child, ul.iconic li:last-child > a {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 0.4rem;
    border-bottom-right-radius: 0.4rem; }

.nav-svg-icon svg {
  width: 2.3rem;
  height: 2.3rem;
  vertical-align: bottom; }

@media only screen and (min-width: 768px) and (max-width: 1024px), only screen and (min-width: 320px) and (max-width: 568px), only screen and (min-width: 320px) and (max-width: 480px) {
  nav ul li:hover > ul, nav ul li:focus > ul {
    display: none; } }
@media print {
  body:before {
    content: "By Matt Gemmell - http://mattgemmell.com"; }

  article a[href^="http"]:after {
    content: " (" attr(href) ")"; }

  a {
    font-weight: bolder;
    text-decoration: none; }

  body {
    color: #000;
    background: #fff; }

  @page {
    margin: 2cm; }
  #wrapper > header, nav, header .meta, article footer, footer .meta {
    display: none; }

  h1 {
    font-size: 1rem;
    margin-bottom: 3rem; }

  article h1 {
    font-size: 2rem; }

  h1, h2, h3 {
    page-break-after: avoid; }

  h2 {
    margin-top: 3rem; }

  h3 {
    margin-top: 2rem; }

  img {
    max-width: 100% !important;
    height: auto;
    margin: 2rem auto; }

  .screenshot {
    text-align: center;
    margin: 2rem auto; }

  ul, img {
    page-break-inside: avoid; }

  #wrapper > footer {
    margin-top: 5rem; }

  hr {
    border: 0.1rem solid #999;
    height: 0rem;
    background: #999;
    margin: 2rem 0; } }
